blob: 79f9557890db6c321f14c112c942d36f50973ef4 [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{},
Sami Väisänen74c23472016-05-09 17:30:30 +0300284 mPrimitiveRestart(false),
Geoff Lang4fb8a8b2018-06-01 16:47:57 -0400285 mDebug(debug),
Sami Väisänen74c23472016-05-09 17:30:30 +0300286 mMultiSampling(false),
Geoff Lang1d2c41d2016-10-19 16:14:46 -0700287 mSampleAlphaToOne(false),
Jamie Madille08a1d32017-03-07 17:24:06 -0500288 mFramebufferSRGB(true),
Geoff Lang4fb8a8b2018-06-01 16:47:57 -0400289 mRobustResourceInit(robustResourceInit),
jchen1082af6202018-06-22 10:59:52 +0800290 mProgramBinaryCacheEnabled(programBinaryCacheEnabled),
291 mMaxShaderCompilerThreads(std::numeric_limits<GLuint>::max())
Jamie Madillb980c562018-11-27 11:34:27 -0500292{}
Geoff Lang76b10c92014-09-05 16:28:14 -0400293
Jamie Madillb980c562018-11-27 11:34:27 -0500294State::~State() {}
Geoff Lang76b10c92014-09-05 16:28:14 -0400295
Jamie Madill6c43a012018-08-08 15:49:27 -0400296void State::initialize(Context *context)
Geoff Lang76b10c92014-09-05 16:28:14 -0400297{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700298 const Caps &caps = context->getCaps();
299 const Extensions &extensions = context->getExtensions();
Geoff Lang4751aab2017-10-30 15:14:52 -0400300 const Extensions &nativeExtensions = context->getImplementation()->getNativeExtensions();
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700301 const Version &clientVersion = context->getClientVersion();
Jamie Madill4928b7c2017-06-20 12:57:39 -0400302
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700303 mMaxDrawBuffers = caps.maxDrawBuffers;
Shannon Woods2df6a602014-09-26 16:12:07 -0400304 mMaxCombinedTextureImageUnits = caps.maxCombinedTextureImageUnits;
Shannon Woods53a94a82014-06-24 15:20:36 -0400305
Jamie Madillf75ab352015-03-16 10:46:52 -0400306 setColorClearValue(0.0f, 0.0f, 0.0f, 0.0f);
Shannon Woods53a94a82014-06-24 15:20:36 -0400307
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700308 mDepthClearValue = 1.0f;
Shannon Woods53a94a82014-06-24 15:20:36 -0400309 mStencilClearValue = 0;
310
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700311 mScissorTest = false;
312 mScissor.x = 0;
313 mScissor.y = 0;
314 mScissor.width = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400315 mScissor.height = 0;
316
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700317 mBlendColor.red = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400318 mBlendColor.green = 0;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700319 mBlendColor.blue = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400320 mBlendColor.alpha = 0;
321
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700322 mStencilRef = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400323 mStencilBackRef = 0;
324
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700325 mSampleCoverage = false;
326 mSampleCoverageValue = 1.0f;
Shannon Woods53a94a82014-06-24 15:20:36 -0400327 mSampleCoverageInvert = false;
Jiawei Shaodb342272017-09-27 10:21:45 +0800328
329 mMaxSampleMaskWords = caps.maxSampleMaskWords;
330 mSampleMask = false;
331 mSampleMaskValues.fill(~GLbitfield(0));
332
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700333 mGenerateMipmapHint = GL_DONT_CARE;
Shannon Woods53a94a82014-06-24 15:20:36 -0400334 mFragmentShaderDerivativeHint = GL_DONT_CARE;
335
336 mLineWidth = 1.0f;
337
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700338 mViewport.x = 0;
339 mViewport.y = 0;
340 mViewport.width = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400341 mViewport.height = 0;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700342 mNearZ = 0.0f;
343 mFarZ = 1.0f;
Shannon Woods53a94a82014-06-24 15:20:36 -0400344
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700345 mBlend.colorMaskRed = true;
Shannon Woods53a94a82014-06-24 15:20:36 -0400346 mBlend.colorMaskGreen = true;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700347 mBlend.colorMaskBlue = true;
Shannon Woods53a94a82014-06-24 15:20:36 -0400348 mBlend.colorMaskAlpha = true;
349
Geoff Lang76b10c92014-09-05 16:28:14 -0400350 mActiveSampler = 0;
351
Shannon Woods23e05002014-09-22 19:07:27 -0400352 mVertexAttribCurrentValues.resize(caps.maxVertexAttributes);
Shannon Woods53a94a82014-06-24 15:20:36 -0400353
Brandon Jonesc405ae72017-12-06 14:15:03 -0800354 // Set all indexes in state attributes type mask to float (default)
355 for (int i = 0; i < MAX_VERTEX_ATTRIBS; i++)
356 {
357 mCurrentValuesTypeMask.setIndex(GL_FLOAT, i);
358 }
359
Geoff Lang4dc3af02016-11-18 14:09:27 -0500360 mUniformBuffers.resize(caps.maxUniformBufferBindings);
Shannon Woodsf3acaf92014-09-23 18:07:11 -0400361
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800362 mSamplerTextures[TextureType::_2D].resize(caps.maxCombinedTextureImageUnits);
363 mSamplerTextures[TextureType::CubeMap].resize(caps.maxCombinedTextureImageUnits);
Geoff Langeb66a6e2016-10-31 13:06:12 -0400364 if (clientVersion >= Version(3, 0))
Shannon Woods53a94a82014-06-24 15:20:36 -0400365 {
Geoff Lang76b10c92014-09-05 16:28:14 -0400366 // TODO: These could also be enabled via extension
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800367 mSamplerTextures[TextureType::_2DArray].resize(caps.maxCombinedTextureImageUnits);
368 mSamplerTextures[TextureType::_3D].resize(caps.maxCombinedTextureImageUnits);
Shannon Woods53a94a82014-06-24 15:20:36 -0400369 }
Yizhou Jiang7818a852018-09-06 15:02:04 +0800370 if (clientVersion >= Version(3, 1) || nativeExtensions.textureMultisample)
371 {
372 mSamplerTextures[TextureType::_2DMultisample].resize(caps.maxCombinedTextureImageUnits);
373 }
Geoff Lang3b573612016-10-31 14:08:10 -0400374 if (clientVersion >= Version(3, 1))
375 {
Olli Etuahod310a432018-08-24 15:40:23 +0300376 mSamplerTextures[TextureType::_2DMultisampleArray].resize(
377 caps.maxCombinedTextureImageUnits);
Jiajia Qin6eafb042016-12-27 17:04:07 +0800378
379 mAtomicCounterBuffers.resize(caps.maxAtomicCounterBufferBindings);
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800380 mShaderStorageBuffers.resize(caps.maxShaderStorageBufferBindings);
Xinghua Cao65ec0b22017-03-28 16:10:52 +0800381 mImageUnits.resize(caps.maxImageUnits);
Geoff Lang3b573612016-10-31 14:08:10 -0400382 }
Geoff Lang4751aab2017-10-30 15:14:52 -0400383 if (nativeExtensions.textureRectangle)
Corentin Wallez13c0dd42017-07-04 18:27:01 -0400384 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800385 mSamplerTextures[TextureType::Rectangle].resize(caps.maxCombinedTextureImageUnits);
Corentin Wallez13c0dd42017-07-04 18:27:01 -0400386 }
Geoff Lang4751aab2017-10-30 15:14:52 -0400387 if (nativeExtensions.eglImageExternal || nativeExtensions.eglStreamConsumerExternal)
Ian Ewellbda75592016-04-18 17:25:54 -0400388 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800389 mSamplerTextures[TextureType::External].resize(caps.maxCombinedTextureImageUnits);
Ian Ewellbda75592016-04-18 17:25:54 -0400390 }
Jamie Madill81c2e252017-09-09 23:32:46 -0400391 mCompleteTextureBindings.reserve(caps.maxCombinedTextureImageUnits);
392 for (uint32_t textureIndex = 0; textureIndex < caps.maxCombinedTextureImageUnits;
393 ++textureIndex)
394 {
Jamie Madill6c43a012018-08-08 15:49:27 -0400395 mCompleteTextureBindings.emplace_back(context, textureIndex);
Jamie Madill81c2e252017-09-09 23:32:46 -0400396 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400397
Geoff Lang76b10c92014-09-05 16:28:14 -0400398 mSamplers.resize(caps.maxCombinedTextureImageUnits);
Shannon Woods53a94a82014-06-24 15:20:36 -0400399
Corentin Wallezad3ae902018-03-09 13:40:42 -0500400 for (QueryType type : angle::AllEnums<QueryType>())
401 {
402 mActiveQueries[type].set(context, nullptr);
403 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400404
Ian Ewell3ffd78b2016-01-22 16:09:42 -0500405 mProgram = nullptr;
Shannon Woods53a94a82014-06-24 15:20:36 -0400406
Ian Ewell3ffd78b2016-01-22 16:09:42 -0500407 mReadFramebuffer = nullptr;
408 mDrawFramebuffer = nullptr;
Jamie Madillb4b53c52015-02-03 15:22:48 -0500409
410 mPrimitiveRestart = false;
Geoff Lang70d0f492015-12-10 17:45:46 -0500411
Geoff Lang70d0f492015-12-10 17:45:46 -0500412 mDebug.setMaxLoggedMessages(extensions.maxDebugLoggedMessages);
Sami Väisänen74c23472016-05-09 17:30:30 +0300413
Geoff Lang488130e2017-09-27 13:53:11 -0400414 mMultiSampling = true;
415 mSampleAlphaToOne = false;
Sami Väisänena797e062016-05-12 15:23:40 +0300416
417 mCoverageModulation = GL_NONE;
Sami Väisänene45e53b2016-05-25 10:36:04 +0300418
419 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixProj);
420 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixMV);
421 mPathStencilFunc = GL_ALWAYS;
422 mPathStencilRef = 0;
423 mPathStencilMask = std::numeric_limits<GLuint>::max();
Jamie Madille08a1d32017-03-07 17:24:06 -0500424
Lingfeng Yangdbb9c532018-02-25 19:58:24 -0800425 // GLES1 emulation: Initialize state for GLES1 if version
426 // applies
427 if (clientVersion < Version(2, 0))
428 {
Lingfeng Yange547aac2018-04-05 09:39:20 -0700429 mGLES1State.initialize(context, this);
Lingfeng Yangdbb9c532018-02-25 19:58:24 -0800430 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400431}
432
Jamie Madill6c1f6712017-02-14 19:08:04 -0500433void State::reset(const Context *context)
Shannon Woods53a94a82014-06-24 15:20:36 -0400434{
Jamie Madill8693bdb2017-09-02 15:32:14 -0400435 for (auto &bindingVec : mSamplerTextures)
Shannon Woods53a94a82014-06-24 15:20:36 -0400436 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800437 for (size_t textureIdx = 0; textureIdx < bindingVec.size(); textureIdx++)
Shannon Woods53a94a82014-06-24 15:20:36 -0400438 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800439 bindingVec[textureIdx].set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400440 }
441 }
Geoff Lang76b10c92014-09-05 16:28:14 -0400442 for (size_t samplerIdx = 0; samplerIdx < mSamplers.size(); samplerIdx++)
443 {
Jamie Madill4928b7c2017-06-20 12:57:39 -0400444 mSamplers[samplerIdx].set(context, nullptr);
Geoff Lang76b10c92014-09-05 16:28:14 -0400445 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400446
Xinghua Cao65ec0b22017-03-28 16:10:52 +0800447 for (auto &imageUnit : mImageUnits)
448 {
449 imageUnit.texture.set(context, nullptr);
450 imageUnit.level = 0;
451 imageUnit.layered = false;
452 imageUnit.layer = 0;
453 imageUnit.access = GL_READ_ONLY;
454 imageUnit.format = GL_R32UI;
455 }
456
Jamie Madill4928b7c2017-06-20 12:57:39 -0400457 mRenderbuffer.set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400458
Corentin Wallez336129f2017-10-17 15:55:40 -0400459 for (auto type : angle::AllEnums<BufferBinding>())
460 {
Jamie Madillbf5177d2018-08-21 12:58:20 -0400461 UpdateBufferBinding(context, &mBoundBuffers[type], nullptr, type);
Corentin Wallez336129f2017-10-17 15:55:40 -0400462 }
463
Geoff Lang7dd2e102014-11-10 15:19:26 -0500464 if (mProgram)
465 {
Jamie Madill6c1f6712017-02-14 19:08:04 -0500466 mProgram->release(context);
Geoff Lang7dd2e102014-11-10 15:19:26 -0500467 }
Yunchao Hed7297bf2017-04-19 15:27:10 +0800468 mProgram = nullptr;
Geoff Lang7dd2e102014-11-10 15:19:26 -0500469
Yunchao Hea336b902017-08-02 16:05:21 +0800470 mProgramPipeline.set(context, nullptr);
471
James Darpiniane8a93c62018-01-04 18:02:24 -0800472 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -0400473 mTransformFeedback->onBindingChanged(context, false);
Jamie Madill4928b7c2017-06-20 12:57:39 -0400474 mTransformFeedback.set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400475
Corentin Wallezad3ae902018-03-09 13:40:42 -0500476 for (QueryType type : angle::AllEnums<QueryType>())
Shannon Woods53a94a82014-06-24 15:20:36 -0400477 {
Corentin Wallezad3ae902018-03-09 13:40:42 -0500478 mActiveQueries[type].set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400479 }
480
Corentin Wallez336129f2017-10-17 15:55:40 -0400481 for (auto &buf : mUniformBuffers)
Shannon Woods53a94a82014-06-24 15:20:36 -0400482 {
Jamie Madillbf5177d2018-08-21 12:58:20 -0400483 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::Uniform, 0, 0);
Shannon Woods53a94a82014-06-24 15:20:36 -0400484 }
485
Jiajia Qin6eafb042016-12-27 17:04:07 +0800486 for (auto &buf : mAtomicCounterBuffers)
487 {
Jamie Madillbf5177d2018-08-21 12:58:20 -0400488 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::AtomicCounter, 0, 0);
Jiajia Qin6eafb042016-12-27 17:04:07 +0800489 }
490
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800491 for (auto &buf : mShaderStorageBuffers)
492 {
Jamie Madillbf5177d2018-08-21 12:58:20 -0400493 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::ShaderStorage, 0, 0);
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800494 }
495
Sami Väisänene45e53b2016-05-25 10:36:04 +0300496 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixProj);
497 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixMV);
498 mPathStencilFunc = GL_ALWAYS;
499 mPathStencilRef = 0;
500 mPathStencilMask = std::numeric_limits<GLuint>::max();
501
Jamie Madill1b94d432015-08-07 13:23:23 -0400502 setAllDirtyBits();
Shannon Woods53a94a82014-06-24 15:20:36 -0400503}
504
Jamie Madille3bb6b72018-10-03 17:51:15 -0400505ANGLE_INLINE void State::unsetActiveTextures(ActiveTextureMask textureMask)
506{
507 // Unset any relevant bound textures.
508 for (size_t textureIndex : mProgram->getActiveSamplersMask())
509 {
510 mActiveTexturesCache[textureIndex] = nullptr;
511 mCompleteTextureBindings[textureIndex].reset();
512 }
513}
514
Jamie Madille3e680c2018-12-03 17:49:08 -0500515ANGLE_INLINE void State::updateActiveTextureState(const Context *context,
516 size_t textureIndex,
517 const Sampler *sampler,
518 Texture *texture)
519{
520 if (!texture->isSamplerComplete(context, sampler))
521 {
522 mActiveTexturesCache[textureIndex] = nullptr;
523 }
524 else
525 {
526 mActiveTexturesCache[textureIndex] = texture;
527
528 if (texture->hasAnyDirtyBit())
529 {
530 setTextureDirty(textureIndex);
531 }
532
Jamie Madill132d15c2018-11-30 15:25:38 -0500533 if (mRobustResourceInit && texture->initState() == InitState::MayNeedInit)
Jamie Madille3e680c2018-12-03 17:49:08 -0500534 {
Jamie Madill132d15c2018-11-30 15:25:38 -0500535 mDirtyObjects.set(DIRTY_OBJECT_TEXTURES_INIT);
Jamie Madille3e680c2018-12-03 17:49:08 -0500536 }
537 }
538
539 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
540}
541
542ANGLE_INLINE void State::updateActiveTexture(const Context *context,
543 size_t textureIndex,
544 Texture *texture)
Jamie Madille3bb6b72018-10-03 17:51:15 -0400545{
546 const Sampler *sampler = mSamplers[textureIndex].get();
547
Jamie Madille3e680c2018-12-03 17:49:08 -0500548 mCompleteTextureBindings[textureIndex].bind(texture);
549
Jamie Madille3bb6b72018-10-03 17:51:15 -0400550 if (!texture)
551 {
552 mActiveTexturesCache[textureIndex] = nullptr;
Jamie Madille3e680c2018-12-03 17:49:08 -0500553 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
554 return;
Jamie Madille3bb6b72018-10-03 17:51:15 -0400555 }
556
Jamie Madille3e680c2018-12-03 17:49:08 -0500557 updateActiveTextureState(context, textureIndex, sampler, texture);
Jamie Madille3bb6b72018-10-03 17:51:15 -0400558}
559
Shannon Woods53a94a82014-06-24 15:20:36 -0400560const RasterizerState &State::getRasterizerState() const
561{
562 return mRasterizer;
563}
564
565const BlendState &State::getBlendState() const
566{
567 return mBlend;
568}
569
570const DepthStencilState &State::getDepthStencilState() const
571{
572 return mDepthStencil;
573}
574
Jamie Madillf75ab352015-03-16 10:46:52 -0400575void State::setColorClearValue(float red, float green, float blue, float alpha)
Shannon Woods53a94a82014-06-24 15:20:36 -0400576{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700577 mColorClearValue.red = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400578 mColorClearValue.green = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700579 mColorClearValue.blue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400580 mColorClearValue.alpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400581 mDirtyBits.set(DIRTY_BIT_CLEAR_COLOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400582}
583
Jamie Madillf75ab352015-03-16 10:46:52 -0400584void State::setDepthClearValue(float depth)
Shannon Woods53a94a82014-06-24 15:20:36 -0400585{
586 mDepthClearValue = depth;
Jamie Madill1b94d432015-08-07 13:23:23 -0400587 mDirtyBits.set(DIRTY_BIT_CLEAR_DEPTH);
Shannon Woods53a94a82014-06-24 15:20:36 -0400588}
589
Jamie Madillf75ab352015-03-16 10:46:52 -0400590void State::setStencilClearValue(int stencil)
Shannon Woods53a94a82014-06-24 15:20:36 -0400591{
592 mStencilClearValue = stencil;
Jamie Madill1b94d432015-08-07 13:23:23 -0400593 mDirtyBits.set(DIRTY_BIT_CLEAR_STENCIL);
Shannon Woods53a94a82014-06-24 15:20:36 -0400594}
595
Shannon Woods53a94a82014-06-24 15:20:36 -0400596void State::setColorMask(bool red, bool green, bool blue, bool alpha)
597{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700598 mBlend.colorMaskRed = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400599 mBlend.colorMaskGreen = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700600 mBlend.colorMaskBlue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400601 mBlend.colorMaskAlpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400602 mDirtyBits.set(DIRTY_BIT_COLOR_MASK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400603}
604
605void State::setDepthMask(bool mask)
606{
607 mDepthStencil.depthMask = mask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400608 mDirtyBits.set(DIRTY_BIT_DEPTH_MASK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400609}
610
Shannon Woods53a94a82014-06-24 15:20:36 -0400611void State::setRasterizerDiscard(bool enabled)
612{
613 mRasterizer.rasterizerDiscard = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400614 mDirtyBits.set(DIRTY_BIT_RASTERIZER_DISCARD_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400615}
616
Shannon Woods53a94a82014-06-24 15:20:36 -0400617void State::setCullFace(bool enabled)
618{
619 mRasterizer.cullFace = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400620 mDirtyBits.set(DIRTY_BIT_CULL_FACE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400621}
622
Corentin Wallez2e568cf2017-09-18 17:05:22 -0400623void State::setCullMode(CullFaceMode mode)
Shannon Woods53a94a82014-06-24 15:20:36 -0400624{
625 mRasterizer.cullMode = mode;
Jamie Madill1b94d432015-08-07 13:23:23 -0400626 mDirtyBits.set(DIRTY_BIT_CULL_FACE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400627}
628
629void State::setFrontFace(GLenum front)
630{
631 mRasterizer.frontFace = front;
Jamie Madill1b94d432015-08-07 13:23:23 -0400632 mDirtyBits.set(DIRTY_BIT_FRONT_FACE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400633}
634
Shannon Woods53a94a82014-06-24 15:20:36 -0400635void State::setDepthTest(bool enabled)
636{
637 mDepthStencil.depthTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400638 mDirtyBits.set(DIRTY_BIT_DEPTH_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400639}
640
641void State::setDepthFunc(GLenum depthFunc)
642{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700643 mDepthStencil.depthFunc = depthFunc;
644 mDirtyBits.set(DIRTY_BIT_DEPTH_FUNC);
Shannon Woods53a94a82014-06-24 15:20:36 -0400645}
646
647void State::setDepthRange(float zNear, float zFar)
648{
649 mNearZ = zNear;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700650 mFarZ = zFar;
Jamie Madill1b94d432015-08-07 13:23:23 -0400651 mDirtyBits.set(DIRTY_BIT_DEPTH_RANGE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400652}
653
Shannon Woods53a94a82014-06-24 15:20:36 -0400654void State::setBlend(bool enabled)
655{
656 mBlend.blend = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400657 mDirtyBits.set(DIRTY_BIT_BLEND_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400658}
659
660void State::setBlendFactors(GLenum sourceRGB, GLenum destRGB, GLenum sourceAlpha, GLenum destAlpha)
661{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700662 mBlend.sourceBlendRGB = sourceRGB;
663 mBlend.destBlendRGB = destRGB;
Shannon Woods53a94a82014-06-24 15:20:36 -0400664 mBlend.sourceBlendAlpha = sourceAlpha;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700665 mBlend.destBlendAlpha = destAlpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400666 mDirtyBits.set(DIRTY_BIT_BLEND_FUNCS);
Shannon Woods53a94a82014-06-24 15:20:36 -0400667}
668
669void State::setBlendColor(float red, float green, float blue, float alpha)
670{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700671 mBlendColor.red = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400672 mBlendColor.green = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700673 mBlendColor.blue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400674 mBlendColor.alpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400675 mDirtyBits.set(DIRTY_BIT_BLEND_COLOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400676}
677
678void State::setBlendEquation(GLenum rgbEquation, GLenum alphaEquation)
679{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700680 mBlend.blendEquationRGB = rgbEquation;
Shannon Woods53a94a82014-06-24 15:20:36 -0400681 mBlend.blendEquationAlpha = alphaEquation;
Jamie Madill1b94d432015-08-07 13:23:23 -0400682 mDirtyBits.set(DIRTY_BIT_BLEND_EQUATIONS);
Shannon Woods53a94a82014-06-24 15:20:36 -0400683}
684
Shannon Woods53a94a82014-06-24 15:20:36 -0400685void State::setStencilTest(bool enabled)
686{
687 mDepthStencil.stencilTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400688 mDirtyBits.set(DIRTY_BIT_STENCIL_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400689}
690
691void State::setStencilParams(GLenum stencilFunc, GLint stencilRef, GLuint stencilMask)
692{
693 mDepthStencil.stencilFunc = stencilFunc;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700694 mStencilRef = (stencilRef > 0) ? stencilRef : 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400695 mDepthStencil.stencilMask = stencilMask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400696 mDirtyBits.set(DIRTY_BIT_STENCIL_FUNCS_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400697}
698
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700699void State::setStencilBackParams(GLenum stencilBackFunc,
700 GLint stencilBackRef,
701 GLuint stencilBackMask)
Shannon Woods53a94a82014-06-24 15:20:36 -0400702{
703 mDepthStencil.stencilBackFunc = stencilBackFunc;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700704 mStencilBackRef = (stencilBackRef > 0) ? stencilBackRef : 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400705 mDepthStencil.stencilBackMask = stencilBackMask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400706 mDirtyBits.set(DIRTY_BIT_STENCIL_FUNCS_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400707}
708
709void State::setStencilWritemask(GLuint stencilWritemask)
710{
711 mDepthStencil.stencilWritemask = stencilWritemask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400712 mDirtyBits.set(DIRTY_BIT_STENCIL_WRITEMASK_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400713}
714
715void State::setStencilBackWritemask(GLuint stencilBackWritemask)
716{
717 mDepthStencil.stencilBackWritemask = stencilBackWritemask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400718 mDirtyBits.set(DIRTY_BIT_STENCIL_WRITEMASK_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400719}
720
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700721void State::setStencilOperations(GLenum stencilFail,
722 GLenum stencilPassDepthFail,
723 GLenum stencilPassDepthPass)
Shannon Woods53a94a82014-06-24 15:20:36 -0400724{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700725 mDepthStencil.stencilFail = stencilFail;
Shannon Woods53a94a82014-06-24 15:20:36 -0400726 mDepthStencil.stencilPassDepthFail = stencilPassDepthFail;
727 mDepthStencil.stencilPassDepthPass = stencilPassDepthPass;
Jamie Madill1b94d432015-08-07 13:23:23 -0400728 mDirtyBits.set(DIRTY_BIT_STENCIL_OPS_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400729}
730
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700731void State::setStencilBackOperations(GLenum stencilBackFail,
732 GLenum stencilBackPassDepthFail,
733 GLenum stencilBackPassDepthPass)
Shannon Woods53a94a82014-06-24 15:20:36 -0400734{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700735 mDepthStencil.stencilBackFail = stencilBackFail;
Shannon Woods53a94a82014-06-24 15:20:36 -0400736 mDepthStencil.stencilBackPassDepthFail = stencilBackPassDepthFail;
737 mDepthStencil.stencilBackPassDepthPass = stencilBackPassDepthPass;
Jamie Madill1b94d432015-08-07 13:23:23 -0400738 mDirtyBits.set(DIRTY_BIT_STENCIL_OPS_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400739}
740
Shannon Woods53a94a82014-06-24 15:20:36 -0400741void State::setPolygonOffsetFill(bool enabled)
742{
Jamie Madill1b94d432015-08-07 13:23:23 -0400743 mRasterizer.polygonOffsetFill = enabled;
744 mDirtyBits.set(DIRTY_BIT_POLYGON_OFFSET_FILL_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400745}
746
747void State::setPolygonOffsetParams(GLfloat factor, GLfloat units)
748{
749 // An application can pass NaN values here, so handle this gracefully
750 mRasterizer.polygonOffsetFactor = factor != factor ? 0.0f : factor;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700751 mRasterizer.polygonOffsetUnits = units != units ? 0.0f : units;
Jamie Madill1b94d432015-08-07 13:23:23 -0400752 mDirtyBits.set(DIRTY_BIT_POLYGON_OFFSET);
Shannon Woods53a94a82014-06-24 15:20:36 -0400753}
754
Shannon Woods53a94a82014-06-24 15:20:36 -0400755void State::setSampleAlphaToCoverage(bool enabled)
756{
757 mBlend.sampleAlphaToCoverage = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400758 mDirtyBits.set(DIRTY_BIT_SAMPLE_ALPHA_TO_COVERAGE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400759}
760
Shannon Woods53a94a82014-06-24 15:20:36 -0400761void State::setSampleCoverage(bool enabled)
762{
763 mSampleCoverage = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400764 mDirtyBits.set(DIRTY_BIT_SAMPLE_COVERAGE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400765}
766
767void State::setSampleCoverageParams(GLclampf value, bool invert)
768{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700769 mSampleCoverageValue = value;
Shannon Woods53a94a82014-06-24 15:20:36 -0400770 mSampleCoverageInvert = invert;
Jamie Madill1b94d432015-08-07 13:23:23 -0400771 mDirtyBits.set(DIRTY_BIT_SAMPLE_COVERAGE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400772}
773
Jiawei Shaodb342272017-09-27 10:21:45 +0800774void State::setSampleMaskEnabled(bool enabled)
775{
776 mSampleMask = enabled;
777 mDirtyBits.set(DIRTY_BIT_SAMPLE_MASK_ENABLED);
778}
779
780void State::setSampleMaskParams(GLuint maskNumber, GLbitfield mask)
781{
782 ASSERT(maskNumber < mMaxSampleMaskWords);
783 mSampleMaskValues[maskNumber] = mask;
Jamie Madillc67323a2017-11-02 23:11:41 -0400784 // TODO(jmadill): Use a child dirty bit if we ever use more than two words.
785 mDirtyBits.set(DIRTY_BIT_SAMPLE_MASK);
Jiawei Shaodb342272017-09-27 10:21:45 +0800786}
787
Sami Väisänen74c23472016-05-09 17:30:30 +0300788void State::setSampleAlphaToOne(bool enabled)
789{
790 mSampleAlphaToOne = enabled;
791 mDirtyBits.set(DIRTY_BIT_SAMPLE_ALPHA_TO_ONE);
792}
793
Sami Väisänen74c23472016-05-09 17:30:30 +0300794void State::setMultisampling(bool enabled)
795{
796 mMultiSampling = enabled;
797 mDirtyBits.set(DIRTY_BIT_MULTISAMPLING);
798}
799
Shannon Woods53a94a82014-06-24 15:20:36 -0400800void State::setScissorTest(bool enabled)
801{
802 mScissorTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400803 mDirtyBits.set(DIRTY_BIT_SCISSOR_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400804}
805
806void State::setScissorParams(GLint x, GLint y, GLsizei width, GLsizei height)
807{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700808 mScissor.x = x;
809 mScissor.y = y;
810 mScissor.width = width;
Shannon Woods53a94a82014-06-24 15:20:36 -0400811 mScissor.height = height;
Jamie Madill1b94d432015-08-07 13:23:23 -0400812 mDirtyBits.set(DIRTY_BIT_SCISSOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400813}
814
Shannon Woods53a94a82014-06-24 15:20:36 -0400815void State::setDither(bool enabled)
816{
817 mBlend.dither = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400818 mDirtyBits.set(DIRTY_BIT_DITHER_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400819}
820
Jamie Madillb4b53c52015-02-03 15:22:48 -0500821void State::setPrimitiveRestart(bool enabled)
822{
823 mPrimitiveRestart = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400824 mDirtyBits.set(DIRTY_BIT_PRIMITIVE_RESTART_ENABLED);
Jamie Madillb4b53c52015-02-03 15:22:48 -0500825}
826
Shannon Woods53a94a82014-06-24 15:20:36 -0400827void State::setEnableFeature(GLenum feature, bool enabled)
828{
829 switch (feature)
830 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700831 case GL_MULTISAMPLE_EXT:
832 setMultisampling(enabled);
833 break;
834 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
835 setSampleAlphaToOne(enabled);
836 break;
837 case GL_CULL_FACE:
838 setCullFace(enabled);
839 break;
840 case GL_POLYGON_OFFSET_FILL:
841 setPolygonOffsetFill(enabled);
842 break;
843 case GL_SAMPLE_ALPHA_TO_COVERAGE:
844 setSampleAlphaToCoverage(enabled);
845 break;
846 case GL_SAMPLE_COVERAGE:
847 setSampleCoverage(enabled);
848 break;
849 case GL_SCISSOR_TEST:
850 setScissorTest(enabled);
851 break;
852 case GL_STENCIL_TEST:
853 setStencilTest(enabled);
854 break;
855 case GL_DEPTH_TEST:
856 setDepthTest(enabled);
857 break;
858 case GL_BLEND:
859 setBlend(enabled);
860 break;
861 case GL_DITHER:
862 setDither(enabled);
863 break;
864 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
865 setPrimitiveRestart(enabled);
866 break;
867 case GL_RASTERIZER_DISCARD:
868 setRasterizerDiscard(enabled);
869 break;
870 case GL_SAMPLE_MASK:
871 setSampleMaskEnabled(enabled);
872 break;
873 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
874 mDebug.setOutputSynchronous(enabled);
875 break;
876 case GL_DEBUG_OUTPUT:
877 mDebug.setOutputEnabled(enabled);
878 break;
879 case GL_FRAMEBUFFER_SRGB_EXT:
880 setFramebufferSRGB(enabled);
881 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -0700882
883 // GLES1 emulation
884 case GL_ALPHA_TEST:
885 mGLES1State.mAlphaTestEnabled = enabled;
886 break;
Lingfeng Yang23dc90b2018-04-23 09:01:49 -0700887 case GL_TEXTURE_2D:
888 mGLES1State.mTexUnitEnables[mActiveSampler].set(TextureType::_2D, enabled);
889 break;
890 case GL_TEXTURE_CUBE_MAP:
891 mGLES1State.mTexUnitEnables[mActiveSampler].set(TextureType::CubeMap, enabled);
892 break;
Lingfeng Yangd0febe72018-05-17 22:36:52 -0700893 case GL_LIGHTING:
894 mGLES1State.mLightingEnabled = enabled;
895 break;
896 case GL_LIGHT0:
897 case GL_LIGHT1:
898 case GL_LIGHT2:
899 case GL_LIGHT3:
900 case GL_LIGHT4:
901 case GL_LIGHT5:
902 case GL_LIGHT6:
903 case GL_LIGHT7:
904 mGLES1State.mLights[feature - GL_LIGHT0].enabled = enabled;
905 break;
906 case GL_NORMALIZE:
907 mGLES1State.mNormalizeEnabled = enabled;
908 break;
909 case GL_RESCALE_NORMAL:
910 mGLES1State.mRescaleNormalEnabled = enabled;
911 break;
912 case GL_COLOR_MATERIAL:
913 mGLES1State.mColorMaterialEnabled = enabled;
914 break;
Lingfeng Yang060088a2018-05-30 20:40:57 -0700915 case GL_CLIP_PLANE0:
916 case GL_CLIP_PLANE1:
917 case GL_CLIP_PLANE2:
918 case GL_CLIP_PLANE3:
919 case GL_CLIP_PLANE4:
920 case GL_CLIP_PLANE5:
921 mGLES1State.mClipPlanes[feature - GL_CLIP_PLANE0].enabled = enabled;
922 break;
Lingfeng Yang7ba3f422018-06-01 09:43:04 -0700923 case GL_FOG:
924 mGLES1State.mFogEnabled = enabled;
925 break;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -0700926 case GL_POINT_SMOOTH:
927 mGLES1State.mPointSmoothEnabled = enabled;
928 break;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -0700929 case GL_LINE_SMOOTH:
930 mGLES1State.mLineSmoothEnabled = enabled;
931 break;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -0700932 case GL_POINT_SPRITE_OES:
933 mGLES1State.mPointSpriteEnabled = enabled;
934 break;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -0700935 case GL_COLOR_LOGIC_OP:
936 mGLES1State.mLogicOpEnabled = enabled;
937 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700938 default:
939 UNREACHABLE();
Shannon Woods53a94a82014-06-24 15:20:36 -0400940 }
941}
942
Jamie Madilldfde6ab2016-06-09 07:07:18 -0700943bool State::getEnableFeature(GLenum feature) const
Shannon Woods53a94a82014-06-24 15:20:36 -0400944{
945 switch (feature)
946 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700947 case GL_MULTISAMPLE_EXT:
948 return isMultisamplingEnabled();
949 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
950 return isSampleAlphaToOneEnabled();
951 case GL_CULL_FACE:
952 return isCullFaceEnabled();
953 case GL_POLYGON_OFFSET_FILL:
954 return isPolygonOffsetFillEnabled();
955 case GL_SAMPLE_ALPHA_TO_COVERAGE:
956 return isSampleAlphaToCoverageEnabled();
957 case GL_SAMPLE_COVERAGE:
958 return isSampleCoverageEnabled();
959 case GL_SCISSOR_TEST:
960 return isScissorTestEnabled();
961 case GL_STENCIL_TEST:
962 return isStencilTestEnabled();
963 case GL_DEPTH_TEST:
964 return isDepthTestEnabled();
965 case GL_BLEND:
966 return isBlendEnabled();
967 case GL_DITHER:
968 return isDitherEnabled();
969 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
970 return isPrimitiveRestartEnabled();
971 case GL_RASTERIZER_DISCARD:
972 return isRasterizerDiscardEnabled();
973 case GL_SAMPLE_MASK:
974 return isSampleMaskEnabled();
975 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
976 return mDebug.isOutputSynchronous();
977 case GL_DEBUG_OUTPUT:
978 return mDebug.isOutputEnabled();
979 case GL_BIND_GENERATES_RESOURCE_CHROMIUM:
980 return isBindGeneratesResourceEnabled();
981 case GL_CLIENT_ARRAYS_ANGLE:
982 return areClientArraysEnabled();
983 case GL_FRAMEBUFFER_SRGB_EXT:
984 return getFramebufferSRGB();
985 case GL_ROBUST_RESOURCE_INITIALIZATION_ANGLE:
986 return mRobustResourceInit;
987 case GL_PROGRAM_CACHE_ENABLED_ANGLE:
988 return mProgramBinaryCacheEnabled;
Jamie Madillc43be722017-07-13 16:22:14 -0400989
Lingfeng Yang13b708f2018-03-21 12:14:10 -0700990 // GLES1 emulation
991 case GL_ALPHA_TEST:
992 return mGLES1State.mAlphaTestEnabled;
Lingfeng Yang01074432018-04-16 10:19:51 -0700993 case GL_VERTEX_ARRAY:
994 return mGLES1State.mVertexArrayEnabled;
995 case GL_NORMAL_ARRAY:
996 return mGLES1State.mNormalArrayEnabled;
997 case GL_COLOR_ARRAY:
998 return mGLES1State.mColorArrayEnabled;
999 case GL_POINT_SIZE_ARRAY_OES:
1000 return mGLES1State.mPointSizeArrayEnabled;
1001 case GL_TEXTURE_COORD_ARRAY:
1002 return mGLES1State.mTexCoordArrayEnabled[mGLES1State.mClientActiveTexture];
Lingfeng Yang23dc90b2018-04-23 09:01:49 -07001003 case GL_TEXTURE_2D:
1004 return mGLES1State.mTexUnitEnables[mActiveSampler].test(TextureType::_2D);
1005 case GL_TEXTURE_CUBE_MAP:
1006 return mGLES1State.mTexUnitEnables[mActiveSampler].test(TextureType::CubeMap);
Lingfeng Yangd0febe72018-05-17 22:36:52 -07001007 case GL_LIGHTING:
1008 return mGLES1State.mLightingEnabled;
1009 case GL_LIGHT0:
1010 case GL_LIGHT1:
1011 case GL_LIGHT2:
1012 case GL_LIGHT3:
1013 case GL_LIGHT4:
1014 case GL_LIGHT5:
1015 case GL_LIGHT6:
1016 case GL_LIGHT7:
1017 return mGLES1State.mLights[feature - GL_LIGHT0].enabled;
1018 case GL_NORMALIZE:
1019 return mGLES1State.mNormalizeEnabled;
1020 case GL_RESCALE_NORMAL:
1021 return mGLES1State.mRescaleNormalEnabled;
1022 case GL_COLOR_MATERIAL:
1023 return mGLES1State.mColorMaterialEnabled;
Lingfeng Yang060088a2018-05-30 20:40:57 -07001024 case GL_CLIP_PLANE0:
1025 case GL_CLIP_PLANE1:
1026 case GL_CLIP_PLANE2:
1027 case GL_CLIP_PLANE3:
1028 case GL_CLIP_PLANE4:
1029 case GL_CLIP_PLANE5:
1030 return mGLES1State.mClipPlanes[feature - GL_CLIP_PLANE0].enabled;
Lingfeng Yang7ba3f422018-06-01 09:43:04 -07001031 case GL_FOG:
1032 return mGLES1State.mFogEnabled;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -07001033 case GL_POINT_SMOOTH:
1034 return mGLES1State.mPointSmoothEnabled;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -07001035 case GL_LINE_SMOOTH:
1036 return mGLES1State.mLineSmoothEnabled;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -07001037 case GL_POINT_SPRITE_OES:
1038 return mGLES1State.mPointSpriteEnabled;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -07001039 case GL_COLOR_LOGIC_OP:
1040 return mGLES1State.mLogicOpEnabled;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001041 default:
1042 UNREACHABLE();
1043 return false;
Shannon Woods53a94a82014-06-24 15:20:36 -04001044 }
1045}
1046
1047void State::setLineWidth(GLfloat width)
1048{
1049 mLineWidth = width;
Jamie Madill1b94d432015-08-07 13:23:23 -04001050 mDirtyBits.set(DIRTY_BIT_LINE_WIDTH);
Shannon Woods53a94a82014-06-24 15:20:36 -04001051}
1052
1053void State::setGenerateMipmapHint(GLenum hint)
1054{
1055 mGenerateMipmapHint = hint;
Jamie Madill1b94d432015-08-07 13:23:23 -04001056 mDirtyBits.set(DIRTY_BIT_GENERATE_MIPMAP_HINT);
Shannon Woods53a94a82014-06-24 15:20:36 -04001057}
1058
1059void State::setFragmentShaderDerivativeHint(GLenum hint)
1060{
1061 mFragmentShaderDerivativeHint = hint;
Jamie Madill1b94d432015-08-07 13:23:23 -04001062 mDirtyBits.set(DIRTY_BIT_SHADER_DERIVATIVE_HINT);
Shannon Woods53a94a82014-06-24 15:20:36 -04001063 // TODO: Propagate the hint to shader translator so we can write
1064 // ddx, ddx_coarse, or ddx_fine depending on the hint.
1065 // Ignore for now. It is valid for implementations to ignore hint.
1066}
1067
1068void State::setViewportParams(GLint x, GLint y, GLsizei width, GLsizei height)
1069{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001070 mViewport.x = x;
1071 mViewport.y = y;
1072 mViewport.width = width;
Shannon Woods53a94a82014-06-24 15:20:36 -04001073 mViewport.height = height;
Jamie Madill1b94d432015-08-07 13:23:23 -04001074 mDirtyBits.set(DIRTY_BIT_VIEWPORT);
Shannon Woods53a94a82014-06-24 15:20:36 -04001075}
1076
Shannon Woods53a94a82014-06-24 15:20:36 -04001077void State::setActiveSampler(unsigned int active)
1078{
1079 mActiveSampler = active;
1080}
1081
Jamie Madille3e680c2018-12-03 17:49:08 -05001082void State::setSamplerTexture(const Context *context, TextureType type, Texture *texture)
Shannon Woods53a94a82014-06-24 15:20:36 -04001083{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001084 mSamplerTextures[type][mActiveSampler].set(context, texture);
Jamie Madill14246812018-10-03 17:51:16 -04001085
1086 if (mProgram && mProgram->getActiveSamplersMask()[mActiveSampler] &&
1087 mProgram->getActiveSamplerTypes()[mActiveSampler] == type)
1088 {
Jamie Madille3e680c2018-12-03 17:49:08 -05001089 updateActiveTexture(context, mActiveSampler, texture);
Jamie Madill14246812018-10-03 17:51:16 -04001090 }
1091
Jamie Madill81c2e252017-09-09 23:32:46 -04001092 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
Shannon Woods53a94a82014-06-24 15:20:36 -04001093}
1094
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001095Texture *State::getTargetTexture(TextureType type) const
Jamie Madillc29968b2016-01-20 11:17:23 -05001096{
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001097 return getSamplerTexture(static_cast<unsigned int>(mActiveSampler), type);
Jamie Madillc29968b2016-01-20 11:17:23 -05001098}
1099
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001100GLuint State::getSamplerTextureId(unsigned int sampler, TextureType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001101{
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001102 ASSERT(sampler < mSamplerTextures[type].size());
1103 return mSamplerTextures[type][sampler].id();
Shannon Woods53a94a82014-06-24 15:20:36 -04001104}
1105
Jamie Madilla02315b2017-02-23 14:14:47 -05001106void State::detachTexture(const Context *context, const TextureMap &zeroTextures, GLuint texture)
Shannon Woods53a94a82014-06-24 15:20:36 -04001107{
1108 // Textures have a detach method on State rather than a simple
1109 // removeBinding, because the zero/null texture objects are managed
1110 // separately, and don't have to go through the Context's maps or
1111 // the ResourceManager.
1112
1113 // [OpenGL ES 2.0.24] section 3.8 page 84:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001114 // If a texture object is deleted, it is as if all texture units which are bound to that texture
1115 // object are rebound to texture object zero
Shannon Woods53a94a82014-06-24 15:20:36 -04001116
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001117 for (TextureType type : angle::AllEnums<TextureType>())
Shannon Woods53a94a82014-06-24 15:20:36 -04001118 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001119 TextureBindingVector &textureVector = mSamplerTextures[type];
Jamie Madill81c2e252017-09-09 23:32:46 -04001120 for (BindingPointer<Texture> &binding : textureVector)
Shannon Woods53a94a82014-06-24 15:20:36 -04001121 {
Geoff Lang76b10c92014-09-05 16:28:14 -04001122 if (binding.id() == texture)
Shannon Woods53a94a82014-06-24 15:20:36 -04001123 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001124 Texture *zeroTexture = zeroTextures[type].get();
1125 ASSERT(zeroTexture != nullptr);
Jamie Madille6382c32014-11-07 15:05:26 -05001126 // Zero textures are the "default" textures instead of NULL
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001127 binding.set(context, zeroTexture);
Jamie Madill81c2e252017-09-09 23:32:46 -04001128 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
Shannon Woods53a94a82014-06-24 15:20:36 -04001129 }
1130 }
1131 }
1132
Xinghua Cao65ec0b22017-03-28 16:10:52 +08001133 for (auto &bindingImageUnit : mImageUnits)
1134 {
1135 if (bindingImageUnit.texture.id() == texture)
1136 {
1137 bindingImageUnit.texture.set(context, nullptr);
1138 bindingImageUnit.level = 0;
1139 bindingImageUnit.layered = false;
1140 bindingImageUnit.layer = 0;
1141 bindingImageUnit.access = GL_READ_ONLY;
1142 bindingImageUnit.format = GL_R32UI;
1143 break;
1144 }
1145 }
1146
Shannon Woods53a94a82014-06-24 15:20:36 -04001147 // [OpenGL ES 2.0.24] section 4.4 page 112:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001148 // If a texture object is deleted while its image is attached to the currently bound
1149 // framebuffer, then it is as if Texture2DAttachment had been called, with a texture of 0, for
1150 // each attachment point to which this image was attached in the currently bound framebuffer.
Shannon Woods53a94a82014-06-24 15:20:36 -04001151
Jamie Madill8693bdb2017-09-02 15:32:14 -04001152 if (mReadFramebuffer && mReadFramebuffer->detachTexture(context, texture))
Shannon Woods53a94a82014-06-24 15:20:36 -04001153 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001154 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
Shannon Woods53a94a82014-06-24 15:20:36 -04001155 }
1156
Jamie Madill8693bdb2017-09-02 15:32:14 -04001157 if (mDrawFramebuffer && mDrawFramebuffer->detachTexture(context, texture))
Shannon Woods53a94a82014-06-24 15:20:36 -04001158 {
Jamie Madillef9fcd92018-11-28 14:03:59 -05001159 setDrawFramebufferDirty();
Shannon Woods53a94a82014-06-24 15:20:36 -04001160 }
1161}
1162
Jamie Madill4928b7c2017-06-20 12:57:39 -04001163void State::initializeZeroTextures(const Context *context, const TextureMap &zeroTextures)
Jamie Madille6382c32014-11-07 15:05:26 -05001164{
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001165 for (TextureType type : angle::AllEnums<TextureType>())
Jamie Madille6382c32014-11-07 15:05:26 -05001166 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001167 for (size_t textureUnit = 0; textureUnit < mSamplerTextures[type].size(); ++textureUnit)
Jamie Madille6382c32014-11-07 15:05:26 -05001168 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001169 mSamplerTextures[type][textureUnit].set(context, zeroTextures[type].get());
Jamie Madille6382c32014-11-07 15:05:26 -05001170 }
1171 }
1172}
1173
Jamie Madill4928b7c2017-06-20 12:57:39 -04001174void State::setSamplerBinding(const Context *context, GLuint textureUnit, Sampler *sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001175{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001176 mSamplers[textureUnit].set(context, sampler);
Jamie Madill81c2e252017-09-09 23:32:46 -04001177 mDirtyBits.set(DIRTY_BIT_SAMPLER_BINDINGS);
Jamie Madille25b8002018-09-20 13:39:49 -04001178 // This is overly conservative as it assumes the sampler has never been bound.
1179 setSamplerDirty(textureUnit);
Jamie Madille3e680c2018-12-03 17:49:08 -05001180 onActiveTextureChange(context, textureUnit);
Shannon Woods53a94a82014-06-24 15:20:36 -04001181}
1182
Jamie Madill4928b7c2017-06-20 12:57:39 -04001183void State::detachSampler(const Context *context, GLuint sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001184{
1185 // [OpenGL ES 3.0.2] section 3.8.2 pages 123-124:
1186 // If a sampler object that is currently bound to one or more texture units is
1187 // deleted, it is as though BindSampler is called once for each texture unit to
1188 // which the sampler is bound, with unit set to the texture unit and sampler set to zero.
Jamie Madill81c2e252017-09-09 23:32:46 -04001189 for (BindingPointer<Sampler> &samplerBinding : mSamplers)
Shannon Woods53a94a82014-06-24 15:20:36 -04001190 {
Geoff Lang76b10c92014-09-05 16:28:14 -04001191 if (samplerBinding.id() == sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001192 {
Jamie Madill4928b7c2017-06-20 12:57:39 -04001193 samplerBinding.set(context, nullptr);
Jamie Madill81c2e252017-09-09 23:32:46 -04001194 mDirtyBits.set(DIRTY_BIT_SAMPLER_BINDINGS);
Shannon Woods53a94a82014-06-24 15:20:36 -04001195 }
1196 }
1197}
1198
Jamie Madill4928b7c2017-06-20 12:57:39 -04001199void State::setRenderbufferBinding(const Context *context, Renderbuffer *renderbuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001200{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001201 mRenderbuffer.set(context, renderbuffer);
Jamie Madill8693bdb2017-09-02 15:32:14 -04001202 mDirtyBits.set(DIRTY_BIT_RENDERBUFFER_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001203}
1204
Jamie Madilla02315b2017-02-23 14:14:47 -05001205void State::detachRenderbuffer(const Context *context, GLuint renderbuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001206{
1207 // [OpenGL ES 2.0.24] section 4.4 page 109:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001208 // If a renderbuffer that is currently bound to RENDERBUFFER is deleted, it is as though
1209 // BindRenderbuffer had been executed with the target RENDERBUFFER and name of zero.
Shannon Woods53a94a82014-06-24 15:20:36 -04001210
1211 if (mRenderbuffer.id() == renderbuffer)
1212 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001213 setRenderbufferBinding(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001214 }
1215
1216 // [OpenGL ES 2.0.24] section 4.4 page 111:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001217 // If a renderbuffer object is deleted while its image is attached to the currently bound
1218 // framebuffer, then it is as if FramebufferRenderbuffer had been called, with a renderbuffer of
1219 // 0, for each attachment point to which this image was attached in the currently bound
1220 // framebuffer.
Shannon Woods53a94a82014-06-24 15:20:36 -04001221
1222 Framebuffer *readFramebuffer = mReadFramebuffer;
1223 Framebuffer *drawFramebuffer = mDrawFramebuffer;
1224
Jamie Madill8693bdb2017-09-02 15:32:14 -04001225 if (readFramebuffer && readFramebuffer->detachRenderbuffer(context, renderbuffer))
Shannon Woods53a94a82014-06-24 15:20:36 -04001226 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001227 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
Shannon Woods53a94a82014-06-24 15:20:36 -04001228 }
1229
1230 if (drawFramebuffer && drawFramebuffer != readFramebuffer)
1231 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001232 if (drawFramebuffer->detachRenderbuffer(context, renderbuffer))
1233 {
Jamie Madillef9fcd92018-11-28 14:03:59 -05001234 setDrawFramebufferDirty();
Jamie Madill8693bdb2017-09-02 15:32:14 -04001235 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001236 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001237}
1238
1239void State::setReadFramebufferBinding(Framebuffer *framebuffer)
1240{
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001241 if (mReadFramebuffer == framebuffer)
1242 return;
1243
Shannon Woods53a94a82014-06-24 15:20:36 -04001244 mReadFramebuffer = framebuffer;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001245 mDirtyBits.set(DIRTY_BIT_READ_FRAMEBUFFER_BINDING);
1246
1247 if (mReadFramebuffer && mReadFramebuffer->hasAnyDirtyBit())
1248 {
1249 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
1250 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001251}
1252
1253void State::setDrawFramebufferBinding(Framebuffer *framebuffer)
1254{
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001255 if (mDrawFramebuffer == framebuffer)
1256 return;
1257
Shannon Woods53a94a82014-06-24 15:20:36 -04001258 mDrawFramebuffer = framebuffer;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001259 mDirtyBits.set(DIRTY_BIT_DRAW_FRAMEBUFFER_BINDING);
1260
Jamie Madillef9fcd92018-11-28 14:03:59 -05001261 if (mDrawFramebuffer)
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001262 {
Jamie Madillef9fcd92018-11-28 14:03:59 -05001263 if (mDrawFramebuffer->hasAnyDirtyBit())
1264 {
1265 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
1266 }
1267
1268 if (mRobustResourceInit && mDrawFramebuffer->hasResourceThatNeedsInit())
1269 {
1270 mDirtyObjects.set(DIRTY_OBJECT_DRAW_ATTACHMENTS);
1271 }
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001272 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001273}
1274
1275Framebuffer *State::getTargetFramebuffer(GLenum target) const
1276{
1277 switch (target)
1278 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001279 case GL_READ_FRAMEBUFFER_ANGLE:
1280 return mReadFramebuffer;
1281 case GL_DRAW_FRAMEBUFFER_ANGLE:
1282 case GL_FRAMEBUFFER:
1283 return mDrawFramebuffer;
1284 default:
1285 UNREACHABLE();
Yunchao Hef81ce4a2017-04-24 10:49:17 +08001286 return nullptr;
Shannon Woods53a94a82014-06-24 15:20:36 -04001287 }
1288}
1289
Shannon Woods53a94a82014-06-24 15:20:36 -04001290bool State::removeReadFramebufferBinding(GLuint framebuffer)
1291{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001292 if (mReadFramebuffer != nullptr && mReadFramebuffer->id() == framebuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001293 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001294 setReadFramebufferBinding(nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001295 return true;
1296 }
1297
1298 return false;
1299}
1300
1301bool State::removeDrawFramebufferBinding(GLuint framebuffer)
1302{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001303 if (mReadFramebuffer != nullptr && mDrawFramebuffer->id() == framebuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001304 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001305 setDrawFramebufferBinding(nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001306 return true;
1307 }
1308
1309 return false;
1310}
1311
Jamie Madill7267aa62018-04-17 15:28:21 -04001312void State::setVertexArrayBinding(const Context *context, VertexArray *vertexArray)
Shannon Woods53a94a82014-06-24 15:20:36 -04001313{
James Darpiniane8a93c62018-01-04 18:02:24 -08001314 if (mVertexArray == vertexArray)
1315 return;
1316 if (mVertexArray)
Jamie Madillbf5177d2018-08-21 12:58:20 -04001317 mVertexArray->onBindingChanged(context, -1);
Shannon Woods53a94a82014-06-24 15:20:36 -04001318 mVertexArray = vertexArray;
James Darpiniane8a93c62018-01-04 18:02:24 -08001319 if (vertexArray)
Jamie Madillbf5177d2018-08-21 12:58:20 -04001320 vertexArray->onBindingChanged(context, 1);
Jamie Madill0b9e9032015-08-17 11:51:52 +00001321 mDirtyBits.set(DIRTY_BIT_VERTEX_ARRAY_BINDING);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001322
1323 if (mVertexArray && mVertexArray->hasAnyDirtyBit())
1324 {
1325 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1326 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001327}
1328
Jamie Madill7267aa62018-04-17 15:28:21 -04001329bool State::removeVertexArrayBinding(const Context *context, GLuint vertexArray)
Shannon Woods53a94a82014-06-24 15:20:36 -04001330{
James Darpiniane8a93c62018-01-04 18:02:24 -08001331 if (mVertexArray && mVertexArray->id() == vertexArray)
Shannon Woods53a94a82014-06-24 15:20:36 -04001332 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001333 mVertexArray->onBindingChanged(context, -1);
Yunchao Hed7297bf2017-04-19 15:27:10 +08001334 mVertexArray = nullptr;
Jamie Madill0b9e9032015-08-17 11:51:52 +00001335 mDirtyBits.set(DIRTY_BIT_VERTEX_ARRAY_BINDING);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001336 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001337 return true;
1338 }
1339
1340 return false;
1341}
1342
Markus Tavenrath774fe562018-11-18 14:14:49 +01001343GLuint State::getVertexArrayId() const
1344{
1345 ASSERT(mVertexArray != nullptr);
1346 return mVertexArray->id();
1347}
1348
Jamie Madill4928b7c2017-06-20 12:57:39 -04001349void State::bindVertexBuffer(const Context *context,
1350 GLuint bindingIndex,
Shao80957d92017-02-20 21:25:59 +08001351 Buffer *boundBuffer,
1352 GLintptr offset,
1353 GLsizei stride)
1354{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001355 getVertexArray()->bindVertexBuffer(context, bindingIndex, boundBuffer, offset, stride);
Shao80957d92017-02-20 21:25:59 +08001356 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1357}
1358
Shaodde78e82017-05-22 14:13:27 +08001359void State::setVertexAttribBinding(const Context *context, GLuint attribIndex, GLuint bindingIndex)
Shao80957d92017-02-20 21:25:59 +08001360{
Shaodde78e82017-05-22 14:13:27 +08001361 getVertexArray()->setVertexAttribBinding(context, attribIndex, bindingIndex);
Shao80957d92017-02-20 21:25:59 +08001362 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1363}
1364
1365void State::setVertexAttribFormat(GLuint attribIndex,
1366 GLint size,
1367 GLenum type,
1368 bool normalized,
1369 bool pureInteger,
1370 GLuint relativeOffset)
1371{
1372 getVertexArray()->setVertexAttribFormat(attribIndex, size, type, normalized, pureInteger,
1373 relativeOffset);
1374 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1375}
1376
1377void State::setVertexBindingDivisor(GLuint bindingIndex, GLuint divisor)
1378{
1379 getVertexArray()->setVertexBindingDivisor(bindingIndex, divisor);
1380 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1381}
1382
Jamie Madill6f755b22018-10-09 12:48:54 -04001383angle::Result State::setProgram(const Context *context, Program *newProgram)
Shannon Woods53a94a82014-06-24 15:20:36 -04001384{
Geoff Lang7dd2e102014-11-10 15:19:26 -05001385 if (mProgram != newProgram)
Shannon Woods53a94a82014-06-24 15:20:36 -04001386 {
Geoff Lang7dd2e102014-11-10 15:19:26 -05001387 if (mProgram)
1388 {
Jamie Madille3bb6b72018-10-03 17:51:15 -04001389 unsetActiveTextures(mProgram->getActiveSamplersMask());
Jamie Madill6c1f6712017-02-14 19:08:04 -05001390 mProgram->release(context);
Geoff Lang7dd2e102014-11-10 15:19:26 -05001391 }
1392
1393 mProgram = newProgram;
1394
1395 if (mProgram)
1396 {
1397 newProgram->addRef();
Jamie Madille3bb6b72018-10-03 17:51:15 -04001398 ANGLE_TRY(onProgramExecutableChange(context, newProgram));
Geoff Lang7dd2e102014-11-10 15:19:26 -05001399 }
Jamie Madilldf836ff2018-10-01 10:36:24 -04001400
1401 // Note that rendering is undefined if glUseProgram(0) is called. But ANGLE will generate
1402 // an error if the app tries to draw in this case.
1403
Jamie Madilla779b612017-07-24 11:46:05 -04001404 mDirtyBits.set(DIRTY_BIT_PROGRAM_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001405 }
Jamie Madille3bb6b72018-10-03 17:51:15 -04001406
Jamie Madill7c985f52018-11-29 18:16:17 -05001407 return angle::Result::Continue;
Shannon Woods53a94a82014-06-24 15:20:36 -04001408}
1409
Jamie Madill4928b7c2017-06-20 12:57:39 -04001410void State::setTransformFeedbackBinding(const Context *context,
1411 TransformFeedback *transformFeedback)
Shannon Woods53a94a82014-06-24 15:20:36 -04001412{
James Darpiniane8a93c62018-01-04 18:02:24 -08001413 if (transformFeedback == mTransformFeedback.get())
1414 return;
1415 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -04001416 mTransformFeedback->onBindingChanged(context, false);
Jamie Madill4928b7c2017-06-20 12:57:39 -04001417 mTransformFeedback.set(context, transformFeedback);
James Darpiniane8a93c62018-01-04 18:02:24 -08001418 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -04001419 mTransformFeedback->onBindingChanged(context, true);
Geoff Langded79232017-11-28 15:21:11 -05001420 mDirtyBits.set(DIRTY_BIT_TRANSFORM_FEEDBACK_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001421}
1422
Jamie Madill4928b7c2017-06-20 12:57:39 -04001423bool State::removeTransformFeedbackBinding(const Context *context, GLuint transformFeedback)
Shannon Woods53a94a82014-06-24 15:20:36 -04001424{
1425 if (mTransformFeedback.id() == transformFeedback)
1426 {
James Darpiniane8a93c62018-01-04 18:02:24 -08001427 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -04001428 mTransformFeedback->onBindingChanged(context, false);
Jamie Madill4928b7c2017-06-20 12:57:39 -04001429 mTransformFeedback.set(context, nullptr);
Corentin Walleza2257da2016-04-19 16:43:12 -04001430 return true;
Shannon Woods53a94a82014-06-24 15:20:36 -04001431 }
Corentin Walleza2257da2016-04-19 16:43:12 -04001432
1433 return false;
Shannon Woods53a94a82014-06-24 15:20:36 -04001434}
1435
Yunchao Hea336b902017-08-02 16:05:21 +08001436void State::setProgramPipelineBinding(const Context *context, ProgramPipeline *pipeline)
1437{
1438 mProgramPipeline.set(context, pipeline);
1439}
1440
1441void State::detachProgramPipeline(const Context *context, GLuint pipeline)
1442{
1443 mProgramPipeline.set(context, nullptr);
1444}
1445
Corentin Wallezad3ae902018-03-09 13:40:42 -05001446bool State::isQueryActive(QueryType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001447{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001448 const Query *query = mActiveQueries[type].get();
1449 if (query != nullptr)
Shannon Woods53a94a82014-06-24 15:20:36 -04001450 {
Corentin Wallezad3ae902018-03-09 13:40:42 -05001451 return true;
1452 }
1453
1454 QueryType alternativeType;
1455 if (GetAlternativeQueryType(type, &alternativeType))
1456 {
1457 query = mActiveQueries[alternativeType].get();
1458 return query != nullptr;
Ian Ewell3ffd78b2016-01-22 16:09:42 -05001459 }
1460
1461 return false;
1462}
1463
1464bool State::isQueryActive(Query *query) const
1465{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001466 for (auto &queryPointer : mActiveQueries)
Ian Ewell3ffd78b2016-01-22 16:09:42 -05001467 {
Corentin Wallezad3ae902018-03-09 13:40:42 -05001468 if (queryPointer.get() == query)
Shannon Woods53a94a82014-06-24 15:20:36 -04001469 {
1470 return true;
1471 }
1472 }
1473
1474 return false;
1475}
1476
Corentin Wallezad3ae902018-03-09 13:40:42 -05001477void State::setActiveQuery(const Context *context, QueryType type, Query *query)
Shannon Woods53a94a82014-06-24 15:20:36 -04001478{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001479 mActiveQueries[type].set(context, query);
Shannon Woods53a94a82014-06-24 15:20:36 -04001480}
1481
Corentin Wallezad3ae902018-03-09 13:40:42 -05001482GLuint State::getActiveQueryId(QueryType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001483{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001484 const Query *query = getActiveQuery(type);
Shannon Woods53a94a82014-06-24 15:20:36 -04001485 return (query ? query->id() : 0u);
1486}
1487
Corentin Wallezad3ae902018-03-09 13:40:42 -05001488Query *State::getActiveQuery(QueryType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001489{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001490 return mActiveQueries[type].get();
Shannon Woods53a94a82014-06-24 15:20:36 -04001491}
1492
Geoff Lang91002262018-12-12 16:05:24 -05001493angle::Result State::setIndexedBufferBinding(const Context *context,
1494 BufferBinding target,
1495 GLuint index,
1496 Buffer *buffer,
1497 GLintptr offset,
1498 GLsizeiptr size)
Jiajia Qin9d7d0b12016-11-29 16:30:31 +08001499{
Corentin Wallez336129f2017-10-17 15:55:40 -04001500 setBufferBinding(context, target, buffer);
Jiajia Qin9d7d0b12016-11-29 16:30:31 +08001501
Corentin Wallez336129f2017-10-17 15:55:40 -04001502 switch (target)
1503 {
1504 case BufferBinding::TransformFeedback:
Geoff Lang91002262018-12-12 16:05:24 -05001505 ANGLE_TRY(mTransformFeedback->bindIndexedBuffer(context, index, buffer, offset, size));
James Darpiniane8a93c62018-01-04 18:02:24 -08001506 setBufferBinding(context, target, buffer);
Corentin Wallez336129f2017-10-17 15:55:40 -04001507 break;
1508 case BufferBinding::Uniform:
Jamie Madillbf5177d2018-08-21 12:58:20 -04001509 UpdateIndexedBufferBinding(context, &mUniformBuffers[index], buffer, target, offset,
1510 size);
Corentin Wallez336129f2017-10-17 15:55:40 -04001511 break;
1512 case BufferBinding::AtomicCounter:
Jamie Madillbf5177d2018-08-21 12:58:20 -04001513 UpdateIndexedBufferBinding(context, &mAtomicCounterBuffers[index], buffer, target,
1514 offset, size);
Corentin Wallez336129f2017-10-17 15:55:40 -04001515 break;
1516 case BufferBinding::ShaderStorage:
Jamie Madillbf5177d2018-08-21 12:58:20 -04001517 UpdateIndexedBufferBinding(context, &mShaderStorageBuffers[index], buffer, target,
1518 offset, size);
Corentin Wallez336129f2017-10-17 15:55:40 -04001519 break;
1520 default:
1521 UNREACHABLE();
1522 break;
1523 }
Geoff Lang91002262018-12-12 16:05:24 -05001524
1525 return angle::Result::Continue;
Shannon Woods53a94a82014-06-24 15:20:36 -04001526}
1527
Geoff Lang5d124a62015-09-15 13:03:27 -04001528const OffsetBindingPointer<Buffer> &State::getIndexedUniformBuffer(size_t index) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001529{
Shannon Woodsf3acaf92014-09-23 18:07:11 -04001530 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
Geoff Lang5d124a62015-09-15 13:03:27 -04001531 return mUniformBuffers[index];
Gregoire Payen de La Garanderie68694e92015-03-24 14:03:37 +00001532}
1533
Jiajia Qin6eafb042016-12-27 17:04:07 +08001534const OffsetBindingPointer<Buffer> &State::getIndexedAtomicCounterBuffer(size_t index) const
1535{
1536 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
1537 return mAtomicCounterBuffers[index];
1538}
1539
Jiajia Qinf546e7d2017-03-27 14:12:59 +08001540const OffsetBindingPointer<Buffer> &State::getIndexedShaderStorageBuffer(size_t index) const
1541{
1542 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
1543 return mShaderStorageBuffers[index];
1544}
1545
Corentin Wallez336129f2017-10-17 15:55:40 -04001546Buffer *State::getTargetBuffer(BufferBinding target) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001547{
1548 switch (target)
1549 {
Corentin Wallez336129f2017-10-17 15:55:40 -04001550 case BufferBinding::ElementArray:
Jamie Madillcd0a0a32018-10-18 18:41:57 -04001551 return getVertexArray()->getElementArrayBuffer();
Corentin Wallez336129f2017-10-17 15:55:40 -04001552 default:
1553 return mBoundBuffers[target].get();
Shannon Woods53a94a82014-06-24 15:20:36 -04001554 }
1555}
1556
Geoff Lang91002262018-12-12 16:05:24 -05001557angle::Result State::detachBuffer(const Context *context, const Buffer *buffer)
Yuly Novikov5807a532015-12-03 13:01:22 -05001558{
James Darpinian4d9d4832018-03-13 12:43:28 -07001559 if (!buffer->isBound())
1560 {
Geoff Lang91002262018-12-12 16:05:24 -05001561 return angle::Result::Continue;
James Darpinian4d9d4832018-03-13 12:43:28 -07001562 }
1563 GLuint bufferName = buffer->id();
James Darpiniane8a93c62018-01-04 18:02:24 -08001564 for (auto target : angle::AllEnums<BufferBinding>())
Yuly Novikov5807a532015-12-03 13:01:22 -05001565 {
James Darpiniane8a93c62018-01-04 18:02:24 -08001566 if (mBoundBuffers[target].id() == bufferName)
Yuly Novikov5807a532015-12-03 13:01:22 -05001567 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001568 UpdateBufferBinding(context, &mBoundBuffers[target], nullptr, target);
Yuly Novikov5807a532015-12-03 13:01:22 -05001569 }
1570 }
1571
1572 TransformFeedback *curTransformFeedback = getCurrentTransformFeedback();
1573 if (curTransformFeedback)
1574 {
Geoff Lang91002262018-12-12 16:05:24 -05001575 ANGLE_TRY(curTransformFeedback->detachBuffer(context, bufferName));
Yuly Novikov5807a532015-12-03 13:01:22 -05001576 }
1577
Jamie Madill4928b7c2017-06-20 12:57:39 -04001578 getVertexArray()->detachBuffer(context, bufferName);
James Darpiniane8a93c62018-01-04 18:02:24 -08001579
1580 for (auto &buf : mUniformBuffers)
1581 {
1582 if (buf.id() == bufferName)
1583 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001584 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::Uniform, 0, 0);
James Darpiniane8a93c62018-01-04 18:02:24 -08001585 }
1586 }
1587
1588 for (auto &buf : mAtomicCounterBuffers)
1589 {
1590 if (buf.id() == bufferName)
1591 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001592 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::AtomicCounter, 0, 0);
James Darpiniane8a93c62018-01-04 18:02:24 -08001593 }
1594 }
1595
1596 for (auto &buf : mShaderStorageBuffers)
1597 {
1598 if (buf.id() == bufferName)
1599 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001600 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::ShaderStorage, 0, 0);
James Darpiniane8a93c62018-01-04 18:02:24 -08001601 }
1602 }
Geoff Lang91002262018-12-12 16:05:24 -05001603
1604 return angle::Result::Continue;
Yuly Novikov5807a532015-12-03 13:01:22 -05001605}
1606
Shannon Woods53a94a82014-06-24 15:20:36 -04001607void State::setEnableVertexAttribArray(unsigned int attribNum, bool enabled)
1608{
1609 getVertexArray()->enableAttribute(attribNum, enabled);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001610 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001611}
1612
1613void State::setVertexAttribf(GLuint index, const GLfloat values[4])
1614{
Shannon Woods23e05002014-09-22 19:07:27 -04001615 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001616 mVertexAttribCurrentValues[index].setFloatValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001617 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1618 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001619 mCurrentValuesTypeMask.setIndex(GL_FLOAT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001620}
1621
1622void State::setVertexAttribu(GLuint index, const GLuint values[4])
1623{
Shannon Woods23e05002014-09-22 19:07:27 -04001624 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001625 mVertexAttribCurrentValues[index].setUnsignedIntValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001626 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1627 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001628 mCurrentValuesTypeMask.setIndex(GL_UNSIGNED_INT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001629}
1630
1631void State::setVertexAttribi(GLuint index, const GLint values[4])
1632{
Shannon Woods23e05002014-09-22 19:07:27 -04001633 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001634 mVertexAttribCurrentValues[index].setIntValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001635 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1636 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001637 mCurrentValuesTypeMask.setIndex(GL_INT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001638}
1639
Shaodde78e82017-05-22 14:13:27 +08001640void State::setVertexAttribPointer(const Context *context,
1641 unsigned int attribNum,
1642 Buffer *boundBuffer,
1643 GLint size,
1644 GLenum type,
1645 bool normalized,
1646 bool pureInteger,
1647 GLsizei stride,
1648 const void *pointer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001649{
Shaodde78e82017-05-22 14:13:27 +08001650 getVertexArray()->setVertexAttribPointer(context, attribNum, boundBuffer, size, type,
1651 normalized, pureInteger, stride, pointer);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001652 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Jamie Madill0b9e9032015-08-17 11:51:52 +00001653}
1654
Shaodde78e82017-05-22 14:13:27 +08001655void State::setVertexAttribDivisor(const Context *context, GLuint index, GLuint divisor)
Jamie Madill0b9e9032015-08-17 11:51:52 +00001656{
Shaodde78e82017-05-22 14:13:27 +08001657 getVertexArray()->setVertexAttribDivisor(context, index, divisor);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001658 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001659}
1660
Shannon Woods53a94a82014-06-24 15:20:36 -04001661const void *State::getVertexAttribPointer(unsigned int attribNum) const
1662{
1663 return getVertexArray()->getVertexAttribute(attribNum).pointer;
1664}
1665
1666void State::setPackAlignment(GLint alignment)
1667{
1668 mPack.alignment = alignment;
Jamie Madillc67323a2017-11-02 23:11:41 -04001669 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001670}
1671
Shannon Woods53a94a82014-06-24 15:20:36 -04001672void State::setPackReverseRowOrder(bool reverseRowOrder)
1673{
1674 mPack.reverseRowOrder = reverseRowOrder;
Jamie Madillc67323a2017-11-02 23:11:41 -04001675 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001676}
1677
Minmin Gongadff67b2015-10-14 10:34:45 -04001678void State::setPackRowLength(GLint rowLength)
1679{
1680 mPack.rowLength = rowLength;
Jamie Madillc67323a2017-11-02 23:11:41 -04001681 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001682}
1683
Minmin Gongadff67b2015-10-14 10:34:45 -04001684void State::setPackSkipRows(GLint skipRows)
1685{
1686 mPack.skipRows = skipRows;
Jamie Madillc67323a2017-11-02 23:11:41 -04001687 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001688}
1689
Minmin Gongadff67b2015-10-14 10:34:45 -04001690void State::setPackSkipPixels(GLint skipPixels)
1691{
1692 mPack.skipPixels = skipPixels;
Jamie Madillc67323a2017-11-02 23:11:41 -04001693 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001694}
1695
Shannon Woods53a94a82014-06-24 15:20:36 -04001696void State::setUnpackAlignment(GLint alignment)
1697{
1698 mUnpack.alignment = alignment;
Jamie Madillc67323a2017-11-02 23:11:41 -04001699 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001700}
1701
Minmin Gongb8aee3b2015-01-27 14:42:36 -08001702void State::setUnpackRowLength(GLint rowLength)
1703{
1704 mUnpack.rowLength = rowLength;
Jamie Madillc67323a2017-11-02 23:11:41 -04001705 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongb8aee3b2015-01-27 14:42:36 -08001706}
1707
Minmin Gongadff67b2015-10-14 10:34:45 -04001708void State::setUnpackImageHeight(GLint imageHeight)
1709{
1710 mUnpack.imageHeight = imageHeight;
Jamie Madillc67323a2017-11-02 23:11:41 -04001711 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001712}
1713
Minmin Gongadff67b2015-10-14 10:34:45 -04001714void State::setUnpackSkipImages(GLint skipImages)
1715{
1716 mUnpack.skipImages = skipImages;
Jamie Madillc67323a2017-11-02 23:11:41 -04001717 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001718}
1719
Minmin Gongadff67b2015-10-14 10:34:45 -04001720void State::setUnpackSkipRows(GLint skipRows)
1721{
1722 mUnpack.skipRows = skipRows;
Jamie Madillc67323a2017-11-02 23:11:41 -04001723 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001724}
1725
Minmin Gongadff67b2015-10-14 10:34:45 -04001726void State::setUnpackSkipPixels(GLint skipPixels)
1727{
1728 mUnpack.skipPixels = skipPixels;
Jamie Madillc67323a2017-11-02 23:11:41 -04001729 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001730}
1731
Sami Väisänena797e062016-05-12 15:23:40 +03001732void State::setCoverageModulation(GLenum components)
1733{
1734 mCoverageModulation = components;
1735 mDirtyBits.set(DIRTY_BIT_COVERAGE_MODULATION);
1736}
1737
Sami Väisänene45e53b2016-05-25 10:36:04 +03001738void State::loadPathRenderingMatrix(GLenum matrixMode, const GLfloat *matrix)
1739{
1740 if (matrixMode == GL_PATH_MODELVIEW_CHROMIUM)
1741 {
1742 memcpy(mPathMatrixMV, matrix, 16 * sizeof(GLfloat));
jchen10bb2f2c42018-09-16 09:47:38 +08001743 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING);
Sami Väisänene45e53b2016-05-25 10:36:04 +03001744 }
1745 else if (matrixMode == GL_PATH_PROJECTION_CHROMIUM)
1746 {
1747 memcpy(mPathMatrixProj, matrix, 16 * sizeof(GLfloat));
jchen10bb2f2c42018-09-16 09:47:38 +08001748 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING);
Sami Väisänene45e53b2016-05-25 10:36:04 +03001749 }
1750 else
1751 {
1752 UNREACHABLE();
1753 }
1754}
1755
1756const GLfloat *State::getPathRenderingMatrix(GLenum which) const
1757{
1758 if (which == GL_PATH_MODELVIEW_MATRIX_CHROMIUM)
1759 {
1760 return mPathMatrixMV;
1761 }
1762 else if (which == GL_PATH_PROJECTION_MATRIX_CHROMIUM)
1763 {
1764 return mPathMatrixProj;
1765 }
1766
1767 UNREACHABLE();
1768 return nullptr;
1769}
1770
1771void State::setPathStencilFunc(GLenum func, GLint ref, GLuint mask)
1772{
1773 mPathStencilFunc = func;
1774 mPathStencilRef = ref;
1775 mPathStencilMask = mask;
jchen10bb2f2c42018-09-16 09:47:38 +08001776 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING);
Sami Väisänene45e53b2016-05-25 10:36:04 +03001777}
1778
Geoff Lang1d2c41d2016-10-19 16:14:46 -07001779void State::setFramebufferSRGB(bool sRGB)
1780{
1781 mFramebufferSRGB = sRGB;
1782 mDirtyBits.set(DIRTY_BIT_FRAMEBUFFER_SRGB);
1783}
1784
jchen1082af6202018-06-22 10:59:52 +08001785void State::setMaxShaderCompilerThreads(GLuint count)
1786{
1787 mMaxShaderCompilerThreads = count;
1788}
1789
Shannon Woods53a94a82014-06-24 15:20:36 -04001790void State::getBooleanv(GLenum pname, GLboolean *params)
1791{
1792 switch (pname)
1793 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001794 case GL_SAMPLE_COVERAGE_INVERT:
1795 *params = mSampleCoverageInvert;
1796 break;
1797 case GL_DEPTH_WRITEMASK:
1798 *params = mDepthStencil.depthMask;
1799 break;
1800 case GL_COLOR_WRITEMASK:
1801 params[0] = mBlend.colorMaskRed;
1802 params[1] = mBlend.colorMaskGreen;
1803 params[2] = mBlend.colorMaskBlue;
1804 params[3] = mBlend.colorMaskAlpha;
1805 break;
1806 case GL_CULL_FACE:
1807 *params = mRasterizer.cullFace;
1808 break;
1809 case GL_POLYGON_OFFSET_FILL:
1810 *params = mRasterizer.polygonOffsetFill;
1811 break;
1812 case GL_SAMPLE_ALPHA_TO_COVERAGE:
1813 *params = mBlend.sampleAlphaToCoverage;
1814 break;
1815 case GL_SAMPLE_COVERAGE:
1816 *params = mSampleCoverage;
1817 break;
1818 case GL_SAMPLE_MASK:
1819 *params = mSampleMask;
1820 break;
1821 case GL_SCISSOR_TEST:
1822 *params = mScissorTest;
1823 break;
1824 case GL_STENCIL_TEST:
1825 *params = mDepthStencil.stencilTest;
1826 break;
1827 case GL_DEPTH_TEST:
1828 *params = mDepthStencil.depthTest;
1829 break;
1830 case GL_BLEND:
1831 *params = mBlend.blend;
1832 break;
1833 case GL_DITHER:
1834 *params = mBlend.dither;
1835 break;
1836 case GL_TRANSFORM_FEEDBACK_ACTIVE:
1837 *params = getCurrentTransformFeedback()->isActive() ? GL_TRUE : GL_FALSE;
1838 break;
1839 case GL_TRANSFORM_FEEDBACK_PAUSED:
1840 *params = getCurrentTransformFeedback()->isPaused() ? GL_TRUE : GL_FALSE;
1841 break;
1842 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
1843 *params = mPrimitiveRestart;
1844 break;
1845 case GL_RASTERIZER_DISCARD:
1846 *params = isRasterizerDiscardEnabled() ? GL_TRUE : GL_FALSE;
1847 break;
1848 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
1849 *params = mDebug.isOutputSynchronous() ? GL_TRUE : GL_FALSE;
1850 break;
1851 case GL_DEBUG_OUTPUT:
1852 *params = mDebug.isOutputEnabled() ? GL_TRUE : GL_FALSE;
1853 break;
1854 case GL_MULTISAMPLE_EXT:
1855 *params = mMultiSampling;
1856 break;
1857 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
1858 *params = mSampleAlphaToOne;
1859 break;
1860 case GL_BIND_GENERATES_RESOURCE_CHROMIUM:
1861 *params = isBindGeneratesResourceEnabled() ? GL_TRUE : GL_FALSE;
1862 break;
1863 case GL_CLIENT_ARRAYS_ANGLE:
1864 *params = areClientArraysEnabled() ? GL_TRUE : GL_FALSE;
1865 break;
1866 case GL_FRAMEBUFFER_SRGB_EXT:
1867 *params = getFramebufferSRGB() ? GL_TRUE : GL_FALSE;
1868 break;
1869 case GL_ROBUST_RESOURCE_INITIALIZATION_ANGLE:
1870 *params = mRobustResourceInit ? GL_TRUE : GL_FALSE;
1871 break;
1872 case GL_PROGRAM_CACHE_ENABLED_ANGLE:
1873 *params = mProgramBinaryCacheEnabled ? GL_TRUE : GL_FALSE;
1874 break;
Lingfeng Yangd0febe72018-05-17 22:36:52 -07001875 case GL_LIGHT_MODEL_TWO_SIDE:
1876 *params = IsLightModelTwoSided(&mGLES1State);
1877 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001878 default:
1879 UNREACHABLE();
1880 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04001881 }
1882}
1883
1884void State::getFloatv(GLenum pname, GLfloat *params)
1885{
1886 // Please note: DEPTH_CLEAR_VALUE is included in our internal getFloatv implementation
1887 // because it is stored as a float, despite the fact that the GL ES 2.0 spec names
1888 // GetIntegerv as its native query function. As it would require conversion in any
1889 // case, this should make no difference to the calling application.
1890 switch (pname)
1891 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001892 case GL_LINE_WIDTH:
1893 *params = mLineWidth;
1894 break;
1895 case GL_SAMPLE_COVERAGE_VALUE:
1896 *params = mSampleCoverageValue;
1897 break;
1898 case GL_DEPTH_CLEAR_VALUE:
1899 *params = mDepthClearValue;
1900 break;
1901 case GL_POLYGON_OFFSET_FACTOR:
1902 *params = mRasterizer.polygonOffsetFactor;
1903 break;
1904 case GL_POLYGON_OFFSET_UNITS:
1905 *params = mRasterizer.polygonOffsetUnits;
1906 break;
1907 case GL_DEPTH_RANGE:
1908 params[0] = mNearZ;
1909 params[1] = mFarZ;
1910 break;
1911 case GL_COLOR_CLEAR_VALUE:
1912 params[0] = mColorClearValue.red;
1913 params[1] = mColorClearValue.green;
1914 params[2] = mColorClearValue.blue;
1915 params[3] = mColorClearValue.alpha;
1916 break;
1917 case GL_BLEND_COLOR:
1918 params[0] = mBlendColor.red;
1919 params[1] = mBlendColor.green;
1920 params[2] = mBlendColor.blue;
1921 params[3] = mBlendColor.alpha;
1922 break;
1923 case GL_MULTISAMPLE_EXT:
1924 *params = static_cast<GLfloat>(mMultiSampling);
1925 break;
1926 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
1927 *params = static_cast<GLfloat>(mSampleAlphaToOne);
1928 break;
1929 case GL_COVERAGE_MODULATION_CHROMIUM:
1930 params[0] = static_cast<GLfloat>(mCoverageModulation);
1931 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -07001932 case GL_ALPHA_TEST_REF:
1933 *params = mGLES1State.mAlphaTestRef;
1934 break;
Lingfeng Yanga43994c2018-03-29 07:21:41 -07001935 case GL_CURRENT_COLOR:
1936 {
1937 const auto &color = mGLES1State.mCurrentColor;
1938 params[0] = color.red;
1939 params[1] = color.green;
1940 params[2] = color.blue;
1941 params[3] = color.alpha;
1942 break;
1943 }
Lingfeng Yang5a7e61b2018-03-29 16:50:32 -07001944 case GL_CURRENT_NORMAL:
1945 {
1946 const auto &normal = mGLES1State.mCurrentNormal;
1947 params[0] = normal[0];
1948 params[1] = normal[1];
1949 params[2] = normal[2];
1950 break;
1951 }
Lingfeng Yang038dd532018-03-29 17:31:52 -07001952 case GL_CURRENT_TEXTURE_COORDS:
1953 {
1954 const auto &texcoord = mGLES1State.mCurrentTextureCoords[mActiveSampler];
1955 params[0] = texcoord.s;
1956 params[1] = texcoord.t;
1957 params[2] = texcoord.r;
1958 params[3] = texcoord.q;
1959 break;
1960 }
Lingfeng Yang3a41af62018-04-09 07:28:56 -07001961 case GL_MODELVIEW_MATRIX:
1962 memcpy(params, mGLES1State.mModelviewMatrices.back().data(), 16 * sizeof(GLfloat));
1963 break;
1964 case GL_PROJECTION_MATRIX:
1965 memcpy(params, mGLES1State.mProjectionMatrices.back().data(), 16 * sizeof(GLfloat));
1966 break;
1967 case GL_TEXTURE_MATRIX:
1968 memcpy(params, mGLES1State.mTextureMatrices[mActiveSampler].back().data(),
1969 16 * sizeof(GLfloat));
1970 break;
Lingfeng Yangd0febe72018-05-17 22:36:52 -07001971 case GL_LIGHT_MODEL_AMBIENT:
1972 GetLightModelParameters(&mGLES1State, pname, params);
1973 break;
Lingfeng Yang7ba3f422018-06-01 09:43:04 -07001974 case GL_FOG_MODE:
1975 case GL_FOG_DENSITY:
1976 case GL_FOG_START:
1977 case GL_FOG_END:
1978 case GL_FOG_COLOR:
1979 GetFogParameters(&mGLES1State, pname, params);
1980 break;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -07001981 case GL_POINT_SIZE:
1982 GetPointSize(&mGLES1State, params);
1983 break;
1984 case GL_POINT_SIZE_MIN:
1985 case GL_POINT_SIZE_MAX:
1986 case GL_POINT_FADE_THRESHOLD_SIZE:
1987 case GL_POINT_DISTANCE_ATTENUATION:
1988 GetPointParameter(&mGLES1State, FromGLenum<PointParameter>(pname), params);
1989 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001990 default:
1991 UNREACHABLE();
1992 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04001993 }
1994}
1995
Jamie Madill526392d2018-11-16 09:35:14 -05001996angle::Result State::getIntegerv(const Context *context, GLenum pname, GLint *params)
Shannon Woods53a94a82014-06-24 15:20:36 -04001997{
1998 if (pname >= GL_DRAW_BUFFER0_EXT && pname <= GL_DRAW_BUFFER15_EXT)
1999 {
Geoff Lang3e922062018-11-15 11:26:29 -05002000 size_t drawBuffer = (pname - GL_DRAW_BUFFER0_EXT);
2001 ASSERT(drawBuffer < mMaxDrawBuffers);
Shannon Woods53a94a82014-06-24 15:20:36 -04002002 Framebuffer *framebuffer = mDrawFramebuffer;
Geoff Lang3e922062018-11-15 11:26:29 -05002003 // The default framebuffer may have fewer draw buffer states than a user-created one. The
2004 // user is always allowed to query up to GL_MAX_DRAWBUFFERS so just return GL_NONE here if
2005 // the draw buffer is out of range for this framebuffer.
2006 *params = drawBuffer < framebuffer->getDrawbufferStateCount()
2007 ? framebuffer->getDrawBufferState(drawBuffer)
2008 : GL_NONE;
Jamie Madill7c985f52018-11-29 18:16:17 -05002009 return angle::Result::Continue;
Shannon Woods53a94a82014-06-24 15:20:36 -04002010 }
2011
2012 // Please note: DEPTH_CLEAR_VALUE is not included in our internal getIntegerv implementation
2013 // because it is stored as a float, despite the fact that the GL ES 2.0 spec names
2014 // GetIntegerv as its native query function. As it would require conversion in any
2015 // case, this should make no difference to the calling application. You may find it in
2016 // State::getFloatv.
2017 switch (pname)
2018 {
Corentin Wallez336129f2017-10-17 15:55:40 -04002019 case GL_ARRAY_BUFFER_BINDING:
2020 *params = mBoundBuffers[BufferBinding::Array].id();
2021 break;
2022 case GL_DRAW_INDIRECT_BUFFER_BINDING:
2023 *params = mBoundBuffers[BufferBinding::DrawIndirect].id();
2024 break;
2025 case GL_ELEMENT_ARRAY_BUFFER_BINDING:
Jamie Madillcd0a0a32018-10-18 18:41:57 -04002026 {
2027 Buffer *elementArrayBuffer = getVertexArray()->getElementArrayBuffer();
2028 *params = elementArrayBuffer ? elementArrayBuffer->id() : 0;
Corentin Wallez336129f2017-10-17 15:55:40 -04002029 break;
Jamie Madillcd0a0a32018-10-18 18:41:57 -04002030 }
Jamie Madill690c8eb2018-03-12 15:20:03 -04002031 case GL_DRAW_FRAMEBUFFER_BINDING:
2032 static_assert(GL_DRAW_FRAMEBUFFER_BINDING == GL_DRAW_FRAMEBUFFER_BINDING_ANGLE,
2033 "Enum mismatch");
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002034 *params = mDrawFramebuffer->id();
2035 break;
Jamie Madill690c8eb2018-03-12 15:20:03 -04002036 case GL_READ_FRAMEBUFFER_BINDING:
2037 static_assert(GL_READ_FRAMEBUFFER_BINDING == GL_READ_FRAMEBUFFER_BINDING_ANGLE,
2038 "Enum mismatch");
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002039 *params = mReadFramebuffer->id();
2040 break;
2041 case GL_RENDERBUFFER_BINDING:
2042 *params = mRenderbuffer.id();
2043 break;
2044 case GL_VERTEX_ARRAY_BINDING:
2045 *params = mVertexArray->id();
2046 break;
2047 case GL_CURRENT_PROGRAM:
2048 *params = mProgram ? mProgram->id() : 0;
2049 break;
2050 case GL_PACK_ALIGNMENT:
2051 *params = mPack.alignment;
2052 break;
2053 case GL_PACK_REVERSE_ROW_ORDER_ANGLE:
2054 *params = mPack.reverseRowOrder;
2055 break;
2056 case GL_PACK_ROW_LENGTH:
2057 *params = mPack.rowLength;
2058 break;
2059 case GL_PACK_SKIP_ROWS:
2060 *params = mPack.skipRows;
2061 break;
2062 case GL_PACK_SKIP_PIXELS:
2063 *params = mPack.skipPixels;
2064 break;
2065 case GL_UNPACK_ALIGNMENT:
2066 *params = mUnpack.alignment;
2067 break;
2068 case GL_UNPACK_ROW_LENGTH:
2069 *params = mUnpack.rowLength;
2070 break;
2071 case GL_UNPACK_IMAGE_HEIGHT:
2072 *params = mUnpack.imageHeight;
2073 break;
2074 case GL_UNPACK_SKIP_IMAGES:
2075 *params = mUnpack.skipImages;
2076 break;
2077 case GL_UNPACK_SKIP_ROWS:
2078 *params = mUnpack.skipRows;
2079 break;
2080 case GL_UNPACK_SKIP_PIXELS:
2081 *params = mUnpack.skipPixels;
2082 break;
2083 case GL_GENERATE_MIPMAP_HINT:
2084 *params = mGenerateMipmapHint;
2085 break;
2086 case GL_FRAGMENT_SHADER_DERIVATIVE_HINT_OES:
2087 *params = mFragmentShaderDerivativeHint;
2088 break;
2089 case GL_ACTIVE_TEXTURE:
2090 *params = (static_cast<GLint>(mActiveSampler) + GL_TEXTURE0);
2091 break;
2092 case GL_STENCIL_FUNC:
2093 *params = mDepthStencil.stencilFunc;
2094 break;
2095 case GL_STENCIL_REF:
2096 *params = mStencilRef;
2097 break;
2098 case GL_STENCIL_VALUE_MASK:
2099 *params = CastMaskValue(context, mDepthStencil.stencilMask);
2100 break;
2101 case GL_STENCIL_BACK_FUNC:
2102 *params = mDepthStencil.stencilBackFunc;
2103 break;
2104 case GL_STENCIL_BACK_REF:
2105 *params = mStencilBackRef;
2106 break;
2107 case GL_STENCIL_BACK_VALUE_MASK:
2108 *params = CastMaskValue(context, mDepthStencil.stencilBackMask);
2109 break;
2110 case GL_STENCIL_FAIL:
2111 *params = mDepthStencil.stencilFail;
2112 break;
2113 case GL_STENCIL_PASS_DEPTH_FAIL:
2114 *params = mDepthStencil.stencilPassDepthFail;
2115 break;
2116 case GL_STENCIL_PASS_DEPTH_PASS:
2117 *params = mDepthStencil.stencilPassDepthPass;
2118 break;
2119 case GL_STENCIL_BACK_FAIL:
2120 *params = mDepthStencil.stencilBackFail;
2121 break;
2122 case GL_STENCIL_BACK_PASS_DEPTH_FAIL:
2123 *params = mDepthStencil.stencilBackPassDepthFail;
2124 break;
2125 case GL_STENCIL_BACK_PASS_DEPTH_PASS:
2126 *params = mDepthStencil.stencilBackPassDepthPass;
2127 break;
2128 case GL_DEPTH_FUNC:
2129 *params = mDepthStencil.depthFunc;
2130 break;
2131 case GL_BLEND_SRC_RGB:
2132 *params = mBlend.sourceBlendRGB;
2133 break;
2134 case GL_BLEND_SRC_ALPHA:
2135 *params = mBlend.sourceBlendAlpha;
2136 break;
2137 case GL_BLEND_DST_RGB:
2138 *params = mBlend.destBlendRGB;
2139 break;
2140 case GL_BLEND_DST_ALPHA:
2141 *params = mBlend.destBlendAlpha;
2142 break;
2143 case GL_BLEND_EQUATION_RGB:
2144 *params = mBlend.blendEquationRGB;
2145 break;
2146 case GL_BLEND_EQUATION_ALPHA:
2147 *params = mBlend.blendEquationAlpha;
2148 break;
2149 case GL_STENCIL_WRITEMASK:
2150 *params = CastMaskValue(context, mDepthStencil.stencilWritemask);
2151 break;
2152 case GL_STENCIL_BACK_WRITEMASK:
2153 *params = CastMaskValue(context, mDepthStencil.stencilBackWritemask);
2154 break;
2155 case GL_STENCIL_CLEAR_VALUE:
2156 *params = mStencilClearValue;
2157 break;
2158 case GL_IMPLEMENTATION_COLOR_READ_TYPE:
Jamie Madill690c8eb2018-03-12 15:20:03 -04002159 ANGLE_TRY(mReadFramebuffer->getImplementationColorReadType(
2160 context, reinterpret_cast<GLenum *>(params)));
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002161 break;
2162 case GL_IMPLEMENTATION_COLOR_READ_FORMAT:
Jamie Madill690c8eb2018-03-12 15:20:03 -04002163 ANGLE_TRY(mReadFramebuffer->getImplementationColorReadFormat(
2164 context, reinterpret_cast<GLenum *>(params)));
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002165 break;
2166 case GL_SAMPLE_BUFFERS:
2167 case GL_SAMPLES:
Shannon Woods53a94a82014-06-24 15:20:36 -04002168 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002169 Framebuffer *framebuffer = mDrawFramebuffer;
Jamie Madill427064d2018-04-13 16:20:34 -04002170 if (framebuffer->isComplete(context))
Shannon Woods53a94a82014-06-24 15:20:36 -04002171 {
Jamie Madill427064d2018-04-13 16:20:34 -04002172 GLint samples = framebuffer->getSamples(context);
Shannon Woods53a94a82014-06-24 15:20:36 -04002173 switch (pname)
2174 {
Jamie Madilla0016b72017-07-14 14:30:46 -04002175 case GL_SAMPLE_BUFFERS:
Jamie Madille98b1b52018-03-08 09:47:23 -05002176 if (samples != 0)
Jamie Madilla0016b72017-07-14 14:30:46 -04002177 {
2178 *params = 1;
2179 }
2180 else
2181 {
2182 *params = 0;
2183 }
2184 break;
2185 case GL_SAMPLES:
Jamie Madille98b1b52018-03-08 09:47:23 -05002186 *params = samples;
Jamie Madilla0016b72017-07-14 14:30:46 -04002187 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002188 }
2189 }
2190 else
2191 {
2192 *params = 0;
2193 }
2194 }
2195 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002196 case GL_VIEWPORT:
2197 params[0] = mViewport.x;
2198 params[1] = mViewport.y;
2199 params[2] = mViewport.width;
2200 params[3] = mViewport.height;
2201 break;
2202 case GL_SCISSOR_BOX:
2203 params[0] = mScissor.x;
2204 params[1] = mScissor.y;
2205 params[2] = mScissor.width;
2206 params[3] = mScissor.height;
2207 break;
2208 case GL_CULL_FACE_MODE:
2209 *params = ToGLenum(mRasterizer.cullMode);
2210 break;
2211 case GL_FRONT_FACE:
2212 *params = mRasterizer.frontFace;
2213 break;
2214 case GL_RED_BITS:
2215 case GL_GREEN_BITS:
2216 case GL_BLUE_BITS:
2217 case GL_ALPHA_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002218 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002219 Framebuffer *framebuffer = getDrawFramebuffer();
2220 const FramebufferAttachment *colorbuffer = framebuffer->getFirstColorbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002221
2222 if (colorbuffer)
2223 {
2224 switch (pname)
2225 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002226 case GL_RED_BITS:
2227 *params = colorbuffer->getRedSize();
2228 break;
2229 case GL_GREEN_BITS:
2230 *params = colorbuffer->getGreenSize();
2231 break;
2232 case GL_BLUE_BITS:
2233 *params = colorbuffer->getBlueSize();
2234 break;
2235 case GL_ALPHA_BITS:
2236 *params = colorbuffer->getAlphaSize();
2237 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002238 }
2239 }
2240 else
2241 {
2242 *params = 0;
2243 }
2244 }
2245 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002246 case GL_DEPTH_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002247 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002248 const Framebuffer *framebuffer = getDrawFramebuffer();
2249 const FramebufferAttachment *depthbuffer = framebuffer->getDepthbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002250
2251 if (depthbuffer)
2252 {
2253 *params = depthbuffer->getDepthSize();
2254 }
2255 else
2256 {
2257 *params = 0;
2258 }
2259 }
2260 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002261 case GL_STENCIL_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002262 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002263 const Framebuffer *framebuffer = getDrawFramebuffer();
2264 const FramebufferAttachment *stencilbuffer = framebuffer->getStencilbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002265
2266 if (stencilbuffer)
2267 {
2268 *params = stencilbuffer->getStencilSize();
2269 }
2270 else
2271 {
2272 *params = 0;
2273 }
2274 }
2275 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002276 case GL_TEXTURE_BINDING_2D:
2277 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2278 *params =
2279 getSamplerTextureId(static_cast<unsigned int>(mActiveSampler), TextureType::_2D);
2280 break;
2281 case GL_TEXTURE_BINDING_RECTANGLE_ANGLE:
2282 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2283 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2284 TextureType::Rectangle);
2285 break;
2286 case GL_TEXTURE_BINDING_CUBE_MAP:
2287 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2288 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2289 TextureType::CubeMap);
2290 break;
2291 case GL_TEXTURE_BINDING_3D:
2292 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2293 *params =
2294 getSamplerTextureId(static_cast<unsigned int>(mActiveSampler), TextureType::_3D);
2295 break;
2296 case GL_TEXTURE_BINDING_2D_ARRAY:
2297 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2298 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2299 TextureType::_2DArray);
2300 break;
2301 case GL_TEXTURE_BINDING_2D_MULTISAMPLE:
2302 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2303 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2304 TextureType::_2DMultisample);
2305 break;
Olli Etuahodff32a02018-08-28 14:35:50 +03002306 case GL_TEXTURE_BINDING_2D_MULTISAMPLE_ARRAY:
2307 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2308 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2309 TextureType::_2DMultisampleArray);
2310 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002311 case GL_TEXTURE_BINDING_EXTERNAL_OES:
2312 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2313 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2314 TextureType::External);
2315 break;
2316 case GL_UNIFORM_BUFFER_BINDING:
2317 *params = mBoundBuffers[BufferBinding::Uniform].id();
2318 break;
2319 case GL_TRANSFORM_FEEDBACK_BINDING:
2320 *params = mTransformFeedback.id();
2321 break;
2322 case GL_TRANSFORM_FEEDBACK_BUFFER_BINDING:
2323 *params = mBoundBuffers[BufferBinding::TransformFeedback].id();
2324 break;
2325 case GL_COPY_READ_BUFFER_BINDING:
2326 *params = mBoundBuffers[BufferBinding::CopyRead].id();
2327 break;
2328 case GL_COPY_WRITE_BUFFER_BINDING:
2329 *params = mBoundBuffers[BufferBinding::CopyWrite].id();
2330 break;
2331 case GL_PIXEL_PACK_BUFFER_BINDING:
2332 *params = mBoundBuffers[BufferBinding::PixelPack].id();
2333 break;
2334 case GL_PIXEL_UNPACK_BUFFER_BINDING:
2335 *params = mBoundBuffers[BufferBinding::PixelUnpack].id();
2336 break;
2337 case GL_READ_BUFFER:
2338 *params = mReadFramebuffer->getReadBufferState();
2339 break;
2340 case GL_SAMPLER_BINDING:
2341 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2342 *params = getSamplerId(static_cast<GLuint>(mActiveSampler));
2343 break;
2344 case GL_DEBUG_LOGGED_MESSAGES:
2345 *params = static_cast<GLint>(mDebug.getMessageCount());
2346 break;
2347 case GL_DEBUG_NEXT_LOGGED_MESSAGE_LENGTH:
2348 *params = static_cast<GLint>(mDebug.getNextMessageLength());
2349 break;
2350 case GL_DEBUG_GROUP_STACK_DEPTH:
2351 *params = static_cast<GLint>(mDebug.getGroupStackDepth());
2352 break;
2353 case GL_MULTISAMPLE_EXT:
2354 *params = static_cast<GLint>(mMultiSampling);
2355 break;
2356 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
2357 *params = static_cast<GLint>(mSampleAlphaToOne);
2358 break;
2359 case GL_COVERAGE_MODULATION_CHROMIUM:
2360 *params = static_cast<GLint>(mCoverageModulation);
2361 break;
2362 case GL_ATOMIC_COUNTER_BUFFER_BINDING:
2363 *params = mBoundBuffers[BufferBinding::AtomicCounter].id();
2364 break;
2365 case GL_SHADER_STORAGE_BUFFER_BINDING:
2366 *params = mBoundBuffers[BufferBinding::ShaderStorage].id();
2367 break;
2368 case GL_DISPATCH_INDIRECT_BUFFER_BINDING:
2369 *params = mBoundBuffers[BufferBinding::DispatchIndirect].id();
2370 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -07002371 case GL_ALPHA_TEST_FUNC:
2372 *params = ToGLenum(mGLES1State.mAlphaTestFunc);
2373 break;
Lingfeng Yang96310cd2018-03-28 11:56:28 -07002374 case GL_CLIENT_ACTIVE_TEXTURE:
2375 *params = mGLES1State.mClientActiveTexture + GL_TEXTURE0;
2376 break;
Lingfeng Yangd2488ab2018-04-04 09:25:48 -07002377 case GL_MATRIX_MODE:
2378 *params = ToGLenum(mGLES1State.mMatrixMode);
2379 break;
Lingfeng Yanga0cfa872018-05-30 21:12:17 -07002380 case GL_SHADE_MODEL:
2381 *params = ToGLenum(mGLES1State.mShadeModel);
2382 break;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -07002383 case GL_MODELVIEW_STACK_DEPTH:
2384 case GL_PROJECTION_STACK_DEPTH:
2385 case GL_TEXTURE_STACK_DEPTH:
2386 *params = mGLES1State.getCurrentMatrixStackDepth(pname);
2387 break;
2388 case GL_LOGIC_OP_MODE:
2389 *params = ToGLenum(mGLES1State.mLogicOp);
2390 break;
2391 case GL_BLEND_SRC:
2392 *params = mBlend.sourceBlendRGB;
2393 break;
2394 case GL_BLEND_DST:
2395 *params = mBlend.destBlendRGB;
2396 break;
2397 case GL_PERSPECTIVE_CORRECTION_HINT:
2398 case GL_POINT_SMOOTH_HINT:
2399 case GL_LINE_SMOOTH_HINT:
2400 case GL_FOG_HINT:
2401 *params = mGLES1State.getHint(pname);
2402 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002403 default:
2404 UNREACHABLE();
2405 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002406 }
Jamie Madille98b1b52018-03-08 09:47:23 -05002407
Jamie Madill7c985f52018-11-29 18:16:17 -05002408 return angle::Result::Continue;
Shannon Woods53a94a82014-06-24 15:20:36 -04002409}
2410
Lingfeng Yangabb09f12018-04-16 10:43:53 -07002411void State::getPointerv(const Context *context, GLenum pname, void **params) const
Geoff Lang70d0f492015-12-10 17:45:46 -05002412{
2413 switch (pname)
2414 {
2415 case GL_DEBUG_CALLBACK_FUNCTION:
2416 *params = reinterpret_cast<void *>(mDebug.getCallback());
2417 break;
2418 case GL_DEBUG_CALLBACK_USER_PARAM:
2419 *params = const_cast<void *>(mDebug.getUserParam());
2420 break;
Lingfeng Yangabb09f12018-04-16 10:43:53 -07002421 case GL_VERTEX_ARRAY_POINTER:
2422 case GL_NORMAL_ARRAY_POINTER:
2423 case GL_COLOR_ARRAY_POINTER:
2424 case GL_TEXTURE_COORD_ARRAY_POINTER:
2425 case GL_POINT_SIZE_ARRAY_POINTER_OES:
2426 QueryVertexAttribPointerv(getVertexArray()->getVertexAttribute(
2427 context->vertexArrayIndex(ParamToVertexArrayType(pname))),
2428 GL_VERTEX_ATTRIB_ARRAY_POINTER, params);
2429 return;
Geoff Lang70d0f492015-12-10 17:45:46 -05002430 default:
2431 UNREACHABLE();
2432 break;
2433 }
2434}
2435
Martin Radev66fb8202016-07-28 11:45:20 +03002436void State::getIntegeri_v(GLenum target, GLuint index, GLint *data)
Shannon Woods53a94a82014-06-24 15:20:36 -04002437{
2438 switch (target)
2439 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002440 case GL_TRANSFORM_FEEDBACK_BUFFER_BINDING:
2441 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2442 *data = mTransformFeedback->getIndexedBuffer(index).id();
2443 break;
2444 case GL_UNIFORM_BUFFER_BINDING:
2445 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2446 *data = mUniformBuffers[index].id();
2447 break;
2448 case GL_ATOMIC_COUNTER_BUFFER_BINDING:
2449 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2450 *data = mAtomicCounterBuffers[index].id();
2451 break;
2452 case GL_SHADER_STORAGE_BUFFER_BINDING:
2453 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2454 *data = mShaderStorageBuffers[index].id();
2455 break;
2456 case GL_VERTEX_BINDING_BUFFER:
2457 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2458 *data = mVertexArray->getVertexBinding(index).getBuffer().id();
2459 break;
2460 case GL_VERTEX_BINDING_DIVISOR:
2461 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2462 *data = mVertexArray->getVertexBinding(index).getDivisor();
2463 break;
2464 case GL_VERTEX_BINDING_OFFSET:
2465 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2466 *data = static_cast<GLuint>(mVertexArray->getVertexBinding(index).getOffset());
2467 break;
2468 case GL_VERTEX_BINDING_STRIDE:
2469 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2470 *data = mVertexArray->getVertexBinding(index).getStride();
2471 break;
2472 case GL_SAMPLE_MASK_VALUE:
2473 ASSERT(static_cast<size_t>(index) < mSampleMaskValues.size());
2474 *data = mSampleMaskValues[index];
2475 break;
2476 case GL_IMAGE_BINDING_NAME:
2477 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2478 *data = mImageUnits[index].texture.id();
2479 break;
2480 case GL_IMAGE_BINDING_LEVEL:
2481 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2482 *data = mImageUnits[index].level;
2483 break;
2484 case GL_IMAGE_BINDING_LAYER:
2485 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2486 *data = mImageUnits[index].layer;
2487 break;
2488 case GL_IMAGE_BINDING_ACCESS:
2489 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2490 *data = mImageUnits[index].access;
2491 break;
2492 case GL_IMAGE_BINDING_FORMAT:
2493 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2494 *data = mImageUnits[index].format;
2495 break;
2496 default:
2497 UNREACHABLE();
2498 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002499 }
Shannon Woods53a94a82014-06-24 15:20:36 -04002500}
2501
Martin Radev66fb8202016-07-28 11:45:20 +03002502void State::getInteger64i_v(GLenum target, GLuint index, GLint64 *data)
Shannon Woods53a94a82014-06-24 15:20:36 -04002503{
2504 switch (target)
2505 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002506 case GL_TRANSFORM_FEEDBACK_BUFFER_START:
2507 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2508 *data = mTransformFeedback->getIndexedBuffer(index).getOffset();
2509 break;
2510 case GL_TRANSFORM_FEEDBACK_BUFFER_SIZE:
2511 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2512 *data = mTransformFeedback->getIndexedBuffer(index).getSize();
2513 break;
2514 case GL_UNIFORM_BUFFER_START:
2515 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2516 *data = mUniformBuffers[index].getOffset();
2517 break;
2518 case GL_UNIFORM_BUFFER_SIZE:
2519 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2520 *data = mUniformBuffers[index].getSize();
2521 break;
2522 case GL_ATOMIC_COUNTER_BUFFER_START:
2523 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2524 *data = mAtomicCounterBuffers[index].getOffset();
2525 break;
2526 case GL_ATOMIC_COUNTER_BUFFER_SIZE:
2527 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2528 *data = mAtomicCounterBuffers[index].getSize();
2529 break;
2530 case GL_SHADER_STORAGE_BUFFER_START:
2531 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2532 *data = mShaderStorageBuffers[index].getOffset();
2533 break;
2534 case GL_SHADER_STORAGE_BUFFER_SIZE:
2535 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2536 *data = mShaderStorageBuffers[index].getSize();
2537 break;
2538 default:
2539 UNREACHABLE();
2540 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002541 }
Martin Radev66fb8202016-07-28 11:45:20 +03002542}
Shannon Woods53a94a82014-06-24 15:20:36 -04002543
Martin Radev66fb8202016-07-28 11:45:20 +03002544void State::getBooleani_v(GLenum target, GLuint index, GLboolean *data)
2545{
Xinghua Cao9c8e1a32017-12-06 17:59:58 +08002546 switch (target)
2547 {
2548 case GL_IMAGE_BINDING_LAYERED:
2549 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2550 *data = mImageUnits[index].layered;
2551 break;
2552 default:
2553 UNREACHABLE();
2554 break;
2555 }
Shannon Woods53a94a82014-06-24 15:20:36 -04002556}
2557
Markus Tavenrathf7f8c512018-11-18 15:56:45 +01002558angle::Result State::syncReadFramebuffer(const Context *context)
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002559{
Markus Tavenrathf7f8c512018-11-18 15:56:45 +01002560 ASSERT(mReadFramebuffer);
2561 return mReadFramebuffer->syncState(context);
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002562}
2563
Jamie Madillef9fcd92018-11-28 14:03:59 -05002564angle::Result State::syncDrawFramebuffer(const Context *context)
Markus Tavenrathf7f8c512018-11-18 15:56:45 +01002565{
2566 ASSERT(mDrawFramebuffer);
2567 return mDrawFramebuffer->syncState(context);
2568}
2569
Jamie Madillef9fcd92018-11-28 14:03:59 -05002570angle::Result State::syncDrawAttachments(const Context *context)
2571{
2572 ASSERT(mDrawFramebuffer);
2573 ASSERT(!mDrawFramebuffer->hasAnyDirtyBit());
2574 ASSERT(mRobustResourceInit);
2575 return mDrawFramebuffer->ensureDrawAttachmentsInitialized(context);
2576}
2577
Jamie Madille3e680c2018-12-03 17:49:08 -05002578angle::Result State::syncTextures(const Context *context)
Markus Tavenrathf7f8c512018-11-18 15:56:45 +01002579{
Jamie Madille3e680c2018-12-03 17:49:08 -05002580 if (mDirtyTextures.none())
Jamie Madill7c985f52018-11-29 18:16:17 -05002581 return angle::Result::Continue;
Jamie Madille3e680c2018-12-03 17:49:08 -05002582
2583 for (size_t textureIndex : mDirtyTextures)
2584 {
2585 Texture *texture = mActiveTexturesCache[textureIndex];
2586 if (texture && texture->hasAnyDirtyBit())
2587 {
2588 ANGLE_TRY(texture->syncState(context));
2589 }
2590 }
2591
2592 mDirtyTextures.reset();
Jamie Madill7c985f52018-11-29 18:16:17 -05002593 return angle::Result::Continue;
Markus Tavenrathf7f8c512018-11-18 15:56:45 +01002594}
2595
Markus Tavenrathf7f8c512018-11-18 15:56:45 +01002596angle::Result State::syncSamplers(const Context *context)
Jamie Madille25b8002018-09-20 13:39:49 -04002597{
2598 if (mDirtySamplers.none())
Jamie Madill7c985f52018-11-29 18:16:17 -05002599 return angle::Result::Continue;
Jamie Madille25b8002018-09-20 13:39:49 -04002600
Jamie Madille25b8002018-09-20 13:39:49 -04002601 for (size_t samplerIndex : mDirtySamplers)
2602 {
2603 BindingPointer<Sampler> &sampler = mSamplers[samplerIndex];
2604 if (sampler.get())
2605 {
2606 sampler->syncState(context);
2607 }
2608 }
2609
2610 mDirtySamplers.reset();
Markus Tavenrathf7f8c512018-11-18 15:56:45 +01002611
Jamie Madill7c985f52018-11-29 18:16:17 -05002612 return angle::Result::Continue;
Jamie Madille25b8002018-09-20 13:39:49 -04002613}
2614
Jamie Madille3e680c2018-12-03 17:49:08 -05002615angle::Result State::syncVertexArray(const Context *context)
Jamie Madill81c2e252017-09-09 23:32:46 -04002616{
Jamie Madille3e680c2018-12-03 17:49:08 -05002617 ASSERT(mVertexArray);
2618 return mVertexArray->syncState(context);
2619}
Jamie Madill81c2e252017-09-09 23:32:46 -04002620
Jamie Madille3e680c2018-12-03 17:49:08 -05002621angle::Result State::syncProgram(const Context *context)
2622{
2623 return mProgram->syncState(context);
Jamie Madill81c2e252017-09-09 23:32:46 -04002624}
2625
Jamie Madill132d15c2018-11-30 15:25:38 -05002626angle::Result State::syncTexturesInit(const Context *context)
2627{
2628 ASSERT(mRobustResourceInit);
2629
2630 if (!mProgram)
Jamie Madill7c985f52018-11-29 18:16:17 -05002631 return angle::Result::Continue;
Jamie Madill132d15c2018-11-30 15:25:38 -05002632
2633 for (size_t textureUnitIndex : mProgram->getActiveSamplersMask())
2634 {
2635 Texture *texture = mActiveTexturesCache[textureUnitIndex];
2636 if (texture)
2637 {
2638 ANGLE_TRY(texture->ensureInitialized(context));
2639 }
2640 }
Jamie Madill7c985f52018-11-29 18:16:17 -05002641 return angle::Result::Continue;
Jamie Madill132d15c2018-11-30 15:25:38 -05002642}
2643
2644angle::Result State::syncImagesInit(const Context *context)
2645{
2646 ASSERT(mRobustResourceInit);
2647 ASSERT(mProgram);
2648 for (size_t imageUnitIndex : mProgram->getActiveImagesMask())
2649 {
2650 Texture *texture = mImageUnits[imageUnitIndex].texture.get();
2651 if (texture)
2652 {
2653 ANGLE_TRY(texture->ensureInitialized(context));
2654 }
2655 }
Jamie Madill7c985f52018-11-29 18:16:17 -05002656 return angle::Result::Continue;
Jamie Madill132d15c2018-11-30 15:25:38 -05002657}
2658
Jamie Madill6f755b22018-10-09 12:48:54 -04002659angle::Result State::syncDirtyObject(const Context *context, GLenum target)
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002660{
2661 DirtyObjects localSet;
2662
2663 switch (target)
2664 {
2665 case GL_READ_FRAMEBUFFER:
2666 localSet.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2667 break;
2668 case GL_DRAW_FRAMEBUFFER:
2669 localSet.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2670 break;
2671 case GL_FRAMEBUFFER:
2672 localSet.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2673 localSet.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2674 break;
2675 case GL_VERTEX_ARRAY:
2676 localSet.set(DIRTY_OBJECT_VERTEX_ARRAY);
2677 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002678 case GL_TEXTURE:
Jamie Madille3e680c2018-12-03 17:49:08 -05002679 localSet.set(DIRTY_OBJECT_TEXTURES);
Jamie Madille25b8002018-09-20 13:39:49 -04002680 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002681 case GL_SAMPLER:
Jamie Madille25b8002018-09-20 13:39:49 -04002682 localSet.set(DIRTY_OBJECT_SAMPLERS);
Jamie Madill70aeda42018-08-20 12:17:40 -04002683 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002684 case GL_PROGRAM:
Jamie Madill70aeda42018-08-20 12:17:40 -04002685 localSet.set(DIRTY_OBJECT_PROGRAM);
Jamie Madill81c2e252017-09-09 23:32:46 -04002686 break;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002687 }
2688
Jamie Madillbc918e72018-03-08 09:47:21 -05002689 return syncDirtyObjects(context, localSet);
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002690}
2691
2692void State::setObjectDirty(GLenum target)
2693{
2694 switch (target)
2695 {
2696 case GL_READ_FRAMEBUFFER:
2697 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2698 break;
2699 case GL_DRAW_FRAMEBUFFER:
Jamie Madillef9fcd92018-11-28 14:03:59 -05002700 setDrawFramebufferDirty();
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002701 break;
2702 case GL_FRAMEBUFFER:
2703 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
Jamie Madillef9fcd92018-11-28 14:03:59 -05002704 setDrawFramebufferDirty();
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002705 break;
2706 case GL_VERTEX_ARRAY:
2707 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
2708 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002709 case GL_PROGRAM:
Jamie Madill70aeda42018-08-20 12:17:40 -04002710 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM);
Jamie Madille3e680c2018-12-03 17:49:08 -05002711 break;
2712 default:
Jamie Madill81c2e252017-09-09 23:32:46 -04002713 break;
Jamie Madilla779b612017-07-24 11:46:05 -04002714 }
2715}
2716
Jamie Madill6f755b22018-10-09 12:48:54 -04002717angle::Result State::onProgramExecutableChange(const Context *context, Program *program)
Jamie Madilla779b612017-07-24 11:46:05 -04002718{
2719 // OpenGL Spec:
2720 // "If LinkProgram or ProgramBinary successfully re-links a program object
2721 // that was already in use as a result of a previous call to UseProgram, then the
2722 // generated executable code will be installed as part of the current rendering state."
Jamie Madilldf836ff2018-10-01 10:36:24 -04002723 ASSERT(program->isLinked());
2724
2725 mDirtyBits.set(DIRTY_BIT_PROGRAM_EXECUTABLE);
Jamie Madill956ab4d2018-10-10 16:13:03 -04002726
2727 if (program->hasAnyDirtyBit())
2728 {
2729 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM);
2730 }
Jamie Madille3bb6b72018-10-03 17:51:15 -04002731
2732 // Set any bound textures.
2733 const ActiveTextureTypeArray &textureTypes = program->getActiveSamplerTypes();
2734 for (size_t textureIndex : program->getActiveSamplersMask())
2735 {
2736 TextureType type = textureTypes[textureIndex];
2737
2738 // This can happen if there is a conflicting texture type.
2739 if (type == TextureType::InvalidEnum)
2740 continue;
2741
2742 Texture *texture = mSamplerTextures[type][textureIndex].get();
Jamie Madille3e680c2018-12-03 17:49:08 -05002743 updateActiveTexture(context, textureIndex, texture);
Jamie Madille3bb6b72018-10-03 17:51:15 -04002744 }
2745
2746 for (size_t imageUnitIndex : program->getActiveImagesMask())
2747 {
2748 Texture *image = mImageUnits[imageUnitIndex].texture.get();
2749 if (!image)
2750 continue;
2751
2752 if (image->hasAnyDirtyBit())
2753 {
2754 ANGLE_TRY(image->syncState(context));
2755 }
2756
Jamie Madill132d15c2018-11-30 15:25:38 -05002757 if (mRobustResourceInit && image->initState() == InitState::MayNeedInit)
Jamie Madille3bb6b72018-10-03 17:51:15 -04002758 {
Jamie Madill132d15c2018-11-30 15:25:38 -05002759 mDirtyObjects.set(DIRTY_OBJECT_IMAGES_INIT);
Jamie Madille3bb6b72018-10-03 17:51:15 -04002760 }
2761 }
2762
Jamie Madill7c985f52018-11-29 18:16:17 -05002763 return angle::Result::Continue;
Shannon Woods53a94a82014-06-24 15:20:36 -04002764}
Jamie Madillc9d442d2016-01-20 11:17:24 -05002765
Jamie Madille3e680c2018-12-03 17:49:08 -05002766void State::setTextureDirty(size_t textureUnitIndex)
2767{
2768 mDirtyObjects.set(DIRTY_OBJECT_TEXTURES);
2769 mDirtyTextures.set(textureUnitIndex);
2770}
2771
Jamie Madille25b8002018-09-20 13:39:49 -04002772void State::setSamplerDirty(size_t samplerIndex)
2773{
2774 mDirtyObjects.set(DIRTY_OBJECT_SAMPLERS);
2775 mDirtySamplers.set(samplerIndex);
2776}
2777
Xinghua Cao65ec0b22017-03-28 16:10:52 +08002778void State::setImageUnit(const Context *context,
Will Harris63aa0e52018-09-05 16:15:46 -07002779 size_t unit,
Xinghua Cao65ec0b22017-03-28 16:10:52 +08002780 Texture *texture,
2781 GLint level,
2782 GLboolean layered,
2783 GLint layer,
2784 GLenum access,
2785 GLenum format)
2786{
2787 mImageUnits[unit].texture.set(context, texture);
2788 mImageUnits[unit].level = level;
2789 mImageUnits[unit].layered = layered;
2790 mImageUnits[unit].layer = layer;
2791 mImageUnits[unit].access = access;
2792 mImageUnits[unit].format = format;
jchen1099118c12018-09-10 16:28:51 +08002793 mDirtyBits.set(DIRTY_BIT_IMAGE_BINDINGS);
Jamie Madille3e680c2018-12-03 17:49:08 -05002794
2795 onImageStateChange(context, unit);
Xinghua Cao65ec0b22017-03-28 16:10:52 +08002796}
2797
Jamie Madill81c2e252017-09-09 23:32:46 -04002798// Handle a dirty texture event.
Jamie Madille3e680c2018-12-03 17:49:08 -05002799void State::onActiveTextureChange(const Context *context, size_t textureUnit)
Jamie Madill81c2e252017-09-09 23:32:46 -04002800{
Jamie Madille3e680c2018-12-03 17:49:08 -05002801 if (mProgram)
Geoff Lange51ba632017-11-21 11:45:25 -05002802 {
Jamie Madille3e680c2018-12-03 17:49:08 -05002803 TextureType type = mProgram->getActiveSamplerTypes()[textureUnit];
2804 if (type != TextureType::InvalidEnum)
2805 {
2806 Texture *activeTexture = mSamplerTextures[type][textureUnit].get();
2807 updateActiveTexture(context, textureUnit, activeTexture);
2808 }
2809 }
2810}
2811
2812void State::onActiveTextureStateChange(const Context *context, size_t textureUnit)
2813{
2814 if (mProgram)
2815 {
2816 TextureType type = mProgram->getActiveSamplerTypes()[textureUnit];
2817 if (type != TextureType::InvalidEnum)
2818 {
2819 Texture *activeTexture = mSamplerTextures[type][textureUnit].get();
2820 const Sampler *sampler = mSamplers[textureUnit].get();
2821 updateActiveTextureState(context, textureUnit, sampler, activeTexture);
2822 }
2823 }
2824}
2825
2826void State::onImageStateChange(const Context *context, size_t unit)
2827{
2828 if (mProgram)
2829 {
2830 const ImageUnit &image = mImageUnits[unit];
2831 ASSERT(image.texture.get());
Jamie Madill132d15c2018-11-30 15:25:38 -05002832 if (mRobustResourceInit && image.texture->initState() == InitState::MayNeedInit)
Jamie Madille3e680c2018-12-03 17:49:08 -05002833 {
Jamie Madill132d15c2018-11-30 15:25:38 -05002834 mDirtyObjects.set(DIRTY_OBJECT_IMAGES_INIT);
Jamie Madille3e680c2018-12-03 17:49:08 -05002835 }
Geoff Lange51ba632017-11-21 11:45:25 -05002836 }
Jamie Madill81c2e252017-09-09 23:32:46 -04002837}
2838
Jamie Madill6d32cef2018-08-14 02:34:28 -04002839void State::onUniformBufferStateChange(size_t uniformBufferIndex)
2840{
2841 // This could be represented by a different dirty bit. Using the same one keeps it simple.
2842 mDirtyBits.set(DIRTY_BIT_UNIFORM_BUFFER_BINDINGS);
2843}
2844
Jamie Madillc67323a2017-11-02 23:11:41 -04002845AttributesMask State::getAndResetDirtyCurrentValues() const
2846{
2847 AttributesMask retVal = mDirtyCurrentValues;
2848 mDirtyCurrentValues.reset();
2849 return retVal;
2850}
2851
Markus Tavenrathf7f8c512018-11-18 15:56:45 +01002852constexpr State::DirtyObjectHandler State::kDirtyObjectHandlers[DIRTY_OBJECT_MAX];
2853
Jamie Madillc9d442d2016-01-20 11:17:24 -05002854} // namespace gl