blob: 030a429d3780d59498f846f767c629fee377ee11 [file] [log] [blame]
Shannon Woods53a94a82014-06-24 15:20:36 -04001//
2// Copyright (c) 2014 The ANGLE Project Authors. All rights reserved.
3// Use of this source code is governed by a BSD-style license that can be
4// found in the LICENSE file.
5//
6
7// State.cpp: Implements the State class, encapsulating raw GL state.
8
Geoff Lang2b5420c2014-11-19 14:20:15 -05009#include "libANGLE/State.h"
Shannon Woods53a94a82014-06-24 15:20:36 -040010
Sami Väisänene45e53b2016-05-25 10:36:04 +030011#include <string.h>
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -070012#include <limits>
Sami Väisänene45e53b2016-05-25 10:36:04 +030013
Jamie Madill20e005b2017-04-07 14:19:22 -040014#include "common/bitset_utils.h"
Sami Väisänene45e53b2016-05-25 10:36:04 +030015#include "common/mathutil.h"
jchen10a99ed552017-09-22 08:10:32 +080016#include "common/matrix_utils.h"
Jamie Madillcd0a0a32018-10-18 18:41:57 -040017#include "libANGLE/Buffer.h"
Geoff Lang2b5420c2014-11-19 14:20:15 -050018#include "libANGLE/Caps.h"
jchen10a99ed552017-09-22 08:10:32 +080019#include "libANGLE/Context.h"
Geoff Lang70d0f492015-12-10 17:45:46 -050020#include "libANGLE/Debug.h"
Geoff Lang2b5420c2014-11-19 14:20:15 -050021#include "libANGLE/Framebuffer.h"
22#include "libANGLE/FramebufferAttachment.h"
23#include "libANGLE/Query.h"
24#include "libANGLE/VertexArray.h"
25#include "libANGLE/formatutils.h"
jchen10a99ed552017-09-22 08:10:32 +080026#include "libANGLE/queryconversions.h"
Lingfeng Yangabb09f12018-04-16 10:43:53 -070027#include "libANGLE/queryutils.h"
Geoff Lang4751aab2017-10-30 15:14:52 -040028#include "libANGLE/renderer/ContextImpl.h"
Jamie Madillf668a4b2018-09-23 17:01:20 -040029#include "libANGLE/renderer/TextureImpl.h"
Shannon Woods53a94a82014-06-24 15:20:36 -040030
Corentin Wallezad3ae902018-03-09 13:40:42 -050031namespace gl
32{
33
Olli Etuahobbf1c102016-06-28 13:31:33 +030034namespace
35{
Corentin Wallezad3ae902018-03-09 13:40:42 -050036bool GetAlternativeQueryType(QueryType type, QueryType *alternativeType)
Olli Etuahobbf1c102016-06-28 13:31:33 +030037{
Corentin Wallezad3ae902018-03-09 13:40:42 -050038 switch (type)
39 {
40 case QueryType::AnySamples:
41 *alternativeType = QueryType::AnySamplesConservative;
42 return true;
43 case QueryType::AnySamplesConservative:
44 *alternativeType = QueryType::AnySamples;
45 return true;
46 default:
47 return false;
48 }
Olli Etuahobbf1c102016-06-28 13:31:33 +030049}
50
Jamie Madillca8eda42018-10-18 18:41:56 -040051// Mapping from a buffer binding type to a dirty bit type.
52constexpr angle::PackedEnumMap<BufferBinding, size_t> kBufferBindingDirtyBits = {{
Jamie Madill752d2202018-11-27 13:29:48 -050053 {BufferBinding::AtomicCounter, State::DIRTY_BIT_ATOMIC_COUNTER_BUFFER_BINDING},
54 {BufferBinding::DispatchIndirect, State::DIRTY_BIT_DISPATCH_INDIRECT_BUFFER_BINDING},
55 {BufferBinding::DrawIndirect, State::DIRTY_BIT_DRAW_INDIRECT_BUFFER_BINDING},
56 {BufferBinding::PixelPack, State::DIRTY_BIT_PACK_BUFFER_BINDING},
57 {BufferBinding::PixelUnpack, State::DIRTY_BIT_UNPACK_BUFFER_BINDING},
58 {BufferBinding::ShaderStorage, State::DIRTY_BIT_SHADER_STORAGE_BUFFER_BINDING},
59 {BufferBinding::Uniform, State::DIRTY_BIT_UNIFORM_BUFFER_BINDINGS},
Jamie Madillca8eda42018-10-18 18:41:56 -040060}};
61
62// Returns a buffer binding function depending on if a dirty bit is set.
63template <BufferBinding Target>
Jamie Madill752d2202018-11-27 13:29:48 -050064constexpr std::pair<BufferBinding, State::BufferBindingSetter> GetBufferBindingSetter()
Jamie Madillca8eda42018-10-18 18:41:56 -040065{
Jamie Madill752d2202018-11-27 13:29:48 -050066 return std::make_pair(Target, kBufferBindingDirtyBits[Target] != 0
67 ? &State::setGenericBufferBindingWithBit<Target>
68 : &State::setGenericBufferBinding<Target>);
Jamie Madillca8eda42018-10-18 18:41:56 -040069}
Jamie Madillb980c562018-11-27 11:34:27 -050070} // namespace
Olli Etuahobbf1c102016-06-28 13:31:33 +030071
Jamie Madillbf5177d2018-08-21 12:58:20 -040072template <typename BindingT, typename... ArgsT>
Jamie Madillca8eda42018-10-18 18:41:56 -040073ANGLE_INLINE void UpdateNonTFBufferBinding(const Context *context,
74 BindingT *binding,
75 Buffer *buffer,
76 ArgsT... args)
James Darpiniane8a93c62018-01-04 18:02:24 -080077{
Jamie Madillca8eda42018-10-18 18:41:56 -040078 Buffer *oldBuffer = binding->get();
79 if (oldBuffer)
80 {
81 oldBuffer->onNonTFBindingChanged(-1);
82 oldBuffer->release(context);
83 }
84 binding->assign(buffer, args...);
85 if (buffer)
86 {
87 buffer->addRef();
88 buffer->onNonTFBindingChanged(1);
89 }
Jamie Madillbf5177d2018-08-21 12:58:20 -040090}
91
92template <typename BindingT, typename... ArgsT>
93void UpdateTFBufferBinding(const Context *context, BindingT *binding, bool indexed, ArgsT... args)
94{
95 if (binding->get())
96 (*binding)->onTFBindingChanged(context, false, indexed);
97 binding->set(context, args...);
98 if (binding->get())
99 (*binding)->onTFBindingChanged(context, true, indexed);
James Darpiniane8a93c62018-01-04 18:02:24 -0800100}
101
102void UpdateBufferBinding(const Context *context,
Jamie Madillbf5177d2018-08-21 12:58:20 -0400103 BindingPointer<Buffer> *binding,
James Darpiniane8a93c62018-01-04 18:02:24 -0800104 Buffer *buffer,
Jamie Madillbf5177d2018-08-21 12:58:20 -0400105 BufferBinding target)
James Darpiniane8a93c62018-01-04 18:02:24 -0800106{
Jamie Madillbf5177d2018-08-21 12:58:20 -0400107 if (target == BufferBinding::TransformFeedback)
108 {
109 UpdateTFBufferBinding(context, binding, false, buffer);
110 }
111 else
112 {
113 UpdateNonTFBufferBinding(context, binding, buffer);
114 }
115}
116
117void UpdateIndexedBufferBinding(const Context *context,
118 OffsetBindingPointer<Buffer> *binding,
119 Buffer *buffer,
120 BufferBinding target,
121 GLintptr offset,
122 GLsizeiptr size)
123{
124 if (target == BufferBinding::TransformFeedback)
125 {
126 UpdateTFBufferBinding(context, binding, true, buffer, offset, size);
127 }
128 else
129 {
130 UpdateNonTFBufferBinding(context, binding, buffer, offset, size);
131 }
James Darpiniane8a93c62018-01-04 18:02:24 -0800132}
133
Jamie Madillca8eda42018-10-18 18:41:56 -0400134// These template functions must be defined before they are instantiated in kBufferSetters.
135template <BufferBinding Target>
136void State::setGenericBufferBindingWithBit(const Context *context, Buffer *buffer)
137{
138 UpdateNonTFBufferBinding(context, &mBoundBuffers[Target], buffer);
139 mDirtyBits.set(kBufferBindingDirtyBits[Target]);
140}
141
142template <BufferBinding Target>
143void State::setGenericBufferBinding(const Context *context, Buffer *buffer)
144{
145 UpdateNonTFBufferBinding(context, &mBoundBuffers[Target], buffer);
146}
147
148template <>
149void State::setGenericBufferBinding<BufferBinding::TransformFeedback>(const Context *context,
150 Buffer *buffer)
151{
152 UpdateTFBufferBinding(context, &mBoundBuffers[BufferBinding::TransformFeedback], false, buffer);
153}
154
155template <>
156void State::setGenericBufferBinding<BufferBinding::ElementArray>(const Context *context,
157 Buffer *buffer)
158{
159 Buffer *oldBuffer = mVertexArray->mState.mElementArrayBuffer.get();
160 if (oldBuffer)
161 {
Jamie Madillcd0a0a32018-10-18 18:41:57 -0400162 oldBuffer->removeObserver(&mVertexArray->mState.mElementArrayBuffer);
Jamie Madillca8eda42018-10-18 18:41:56 -0400163 oldBuffer->onNonTFBindingChanged(-1);
164 oldBuffer->release(context);
165 }
166 mVertexArray->mState.mElementArrayBuffer.assign(buffer);
167 if (buffer)
168 {
Jamie Madillcd0a0a32018-10-18 18:41:57 -0400169 buffer->addObserver(&mVertexArray->mState.mElementArrayBuffer);
Jamie Madillca8eda42018-10-18 18:41:56 -0400170 buffer->onNonTFBindingChanged(1);
171 buffer->addRef();
172 }
Jamie Madillca8eda42018-10-18 18:41:56 -0400173 mVertexArray->mDirtyBits.set(VertexArray::DIRTY_BIT_ELEMENT_ARRAY_BUFFER);
Jamie Madillc1fd7372018-10-26 22:48:39 -0400174 mVertexArray->mIndexRangeCache.invalidate();
Jamie Madillca8eda42018-10-18 18:41:56 -0400175 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
176}
177
178const angle::PackedEnumMap<BufferBinding, State::BufferBindingSetter> State::kBufferSetters = {{
179 GetBufferBindingSetter<BufferBinding::Array>(),
180 GetBufferBindingSetter<BufferBinding::AtomicCounter>(),
181 GetBufferBindingSetter<BufferBinding::CopyRead>(),
182 GetBufferBindingSetter<BufferBinding::CopyWrite>(),
183 GetBufferBindingSetter<BufferBinding::DispatchIndirect>(),
184 GetBufferBindingSetter<BufferBinding::DrawIndirect>(),
185 GetBufferBindingSetter<BufferBinding::ElementArray>(),
186 GetBufferBindingSetter<BufferBinding::PixelPack>(),
187 GetBufferBindingSetter<BufferBinding::PixelUnpack>(),
188 GetBufferBindingSetter<BufferBinding::ShaderStorage>(),
189 GetBufferBindingSetter<BufferBinding::TransformFeedback>(),
190 GetBufferBindingSetter<BufferBinding::Uniform>(),
191}};
192
Geoff Lang4fb8a8b2018-06-01 16:47:57 -0400193State::State(bool debug,
194 bool bindGeneratesResource,
195 bool clientArraysEnabled,
196 bool robustResourceInit,
197 bool programBinaryCacheEnabled)
Jamie Madille79b1e12015-11-04 16:36:37 -0500198 : mMaxDrawBuffers(0),
199 mMaxCombinedTextureImageUnits(0),
200 mDepthClearValue(0),
201 mStencilClearValue(0),
202 mScissorTest(false),
203 mSampleCoverage(false),
204 mSampleCoverageValue(0),
205 mSampleCoverageInvert(false),
Jiawei Shaodb342272017-09-27 10:21:45 +0800206 mSampleMask(false),
207 mMaxSampleMaskWords(0),
Jamie Madille79b1e12015-11-04 16:36:37 -0500208 mStencilRef(0),
209 mStencilBackRef(0),
210 mLineWidth(0),
211 mGenerateMipmapHint(GL_NONE),
212 mFragmentShaderDerivativeHint(GL_NONE),
Geoff Lang4fb8a8b2018-06-01 16:47:57 -0400213 mBindGeneratesResource(bindGeneratesResource),
214 mClientArraysEnabled(clientArraysEnabled),
Jamie Madille79b1e12015-11-04 16:36:37 -0500215 mNearZ(0),
216 mFarZ(0),
217 mReadFramebuffer(nullptr),
218 mDrawFramebuffer(nullptr),
219 mProgram(nullptr),
220 mVertexArray(nullptr),
221 mActiveSampler(0),
Jamie Madill4787d702018-08-08 15:49:26 -0400222 mActiveTexturesCache{},
223 mCachedTexturesInitState(InitState::MayNeedInit),
Qin Jiajia47f6dd02018-08-10 13:36:32 +0800224 mCachedImageTexturesInitState(InitState::MayNeedInit),
Sami Väisänen74c23472016-05-09 17:30:30 +0300225 mPrimitiveRestart(false),
Geoff Lang4fb8a8b2018-06-01 16:47:57 -0400226 mDebug(debug),
Sami Väisänen74c23472016-05-09 17:30:30 +0300227 mMultiSampling(false),
Geoff Lang1d2c41d2016-10-19 16:14:46 -0700228 mSampleAlphaToOne(false),
Jamie Madille08a1d32017-03-07 17:24:06 -0500229 mFramebufferSRGB(true),
Geoff Lang4fb8a8b2018-06-01 16:47:57 -0400230 mRobustResourceInit(robustResourceInit),
jchen1082af6202018-06-22 10:59:52 +0800231 mProgramBinaryCacheEnabled(programBinaryCacheEnabled),
232 mMaxShaderCompilerThreads(std::numeric_limits<GLuint>::max())
Jamie Madillb980c562018-11-27 11:34:27 -0500233{}
Geoff Lang76b10c92014-09-05 16:28:14 -0400234
Jamie Madillb980c562018-11-27 11:34:27 -0500235State::~State() {}
Geoff Lang76b10c92014-09-05 16:28:14 -0400236
Jamie Madill6c43a012018-08-08 15:49:27 -0400237void State::initialize(Context *context)
Geoff Lang76b10c92014-09-05 16:28:14 -0400238{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700239 const Caps &caps = context->getCaps();
240 const Extensions &extensions = context->getExtensions();
Geoff Lang4751aab2017-10-30 15:14:52 -0400241 const Extensions &nativeExtensions = context->getImplementation()->getNativeExtensions();
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700242 const Version &clientVersion = context->getClientVersion();
Jamie Madill4928b7c2017-06-20 12:57:39 -0400243
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700244 mMaxDrawBuffers = caps.maxDrawBuffers;
Shannon Woods2df6a602014-09-26 16:12:07 -0400245 mMaxCombinedTextureImageUnits = caps.maxCombinedTextureImageUnits;
Shannon Woods53a94a82014-06-24 15:20:36 -0400246
Jamie Madillf75ab352015-03-16 10:46:52 -0400247 setColorClearValue(0.0f, 0.0f, 0.0f, 0.0f);
Shannon Woods53a94a82014-06-24 15:20:36 -0400248
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700249 mDepthClearValue = 1.0f;
Shannon Woods53a94a82014-06-24 15:20:36 -0400250 mStencilClearValue = 0;
251
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700252 mScissorTest = false;
253 mScissor.x = 0;
254 mScissor.y = 0;
255 mScissor.width = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400256 mScissor.height = 0;
257
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700258 mBlendColor.red = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400259 mBlendColor.green = 0;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700260 mBlendColor.blue = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400261 mBlendColor.alpha = 0;
262
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700263 mStencilRef = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400264 mStencilBackRef = 0;
265
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700266 mSampleCoverage = false;
267 mSampleCoverageValue = 1.0f;
Shannon Woods53a94a82014-06-24 15:20:36 -0400268 mSampleCoverageInvert = false;
Jiawei Shaodb342272017-09-27 10:21:45 +0800269
270 mMaxSampleMaskWords = caps.maxSampleMaskWords;
271 mSampleMask = false;
272 mSampleMaskValues.fill(~GLbitfield(0));
273
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700274 mGenerateMipmapHint = GL_DONT_CARE;
Shannon Woods53a94a82014-06-24 15:20:36 -0400275 mFragmentShaderDerivativeHint = GL_DONT_CARE;
276
277 mLineWidth = 1.0f;
278
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700279 mViewport.x = 0;
280 mViewport.y = 0;
281 mViewport.width = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400282 mViewport.height = 0;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700283 mNearZ = 0.0f;
284 mFarZ = 1.0f;
Shannon Woods53a94a82014-06-24 15:20:36 -0400285
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700286 mBlend.colorMaskRed = true;
Shannon Woods53a94a82014-06-24 15:20:36 -0400287 mBlend.colorMaskGreen = true;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700288 mBlend.colorMaskBlue = true;
Shannon Woods53a94a82014-06-24 15:20:36 -0400289 mBlend.colorMaskAlpha = true;
290
Geoff Lang76b10c92014-09-05 16:28:14 -0400291 mActiveSampler = 0;
292
Shannon Woods23e05002014-09-22 19:07:27 -0400293 mVertexAttribCurrentValues.resize(caps.maxVertexAttributes);
Shannon Woods53a94a82014-06-24 15:20:36 -0400294
Brandon Jonesc405ae72017-12-06 14:15:03 -0800295 // Set all indexes in state attributes type mask to float (default)
296 for (int i = 0; i < MAX_VERTEX_ATTRIBS; i++)
297 {
298 mCurrentValuesTypeMask.setIndex(GL_FLOAT, i);
299 }
300
Geoff Lang4dc3af02016-11-18 14:09:27 -0500301 mUniformBuffers.resize(caps.maxUniformBufferBindings);
Shannon Woodsf3acaf92014-09-23 18:07:11 -0400302
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800303 mSamplerTextures[TextureType::_2D].resize(caps.maxCombinedTextureImageUnits);
304 mSamplerTextures[TextureType::CubeMap].resize(caps.maxCombinedTextureImageUnits);
Geoff Langeb66a6e2016-10-31 13:06:12 -0400305 if (clientVersion >= Version(3, 0))
Shannon Woods53a94a82014-06-24 15:20:36 -0400306 {
Geoff Lang76b10c92014-09-05 16:28:14 -0400307 // TODO: These could also be enabled via extension
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800308 mSamplerTextures[TextureType::_2DArray].resize(caps.maxCombinedTextureImageUnits);
309 mSamplerTextures[TextureType::_3D].resize(caps.maxCombinedTextureImageUnits);
Shannon Woods53a94a82014-06-24 15:20:36 -0400310 }
Yizhou Jiang7818a852018-09-06 15:02:04 +0800311 if (clientVersion >= Version(3, 1) || nativeExtensions.textureMultisample)
312 {
313 mSamplerTextures[TextureType::_2DMultisample].resize(caps.maxCombinedTextureImageUnits);
314 }
Geoff Lang3b573612016-10-31 14:08:10 -0400315 if (clientVersion >= Version(3, 1))
316 {
Olli Etuahod310a432018-08-24 15:40:23 +0300317 mSamplerTextures[TextureType::_2DMultisampleArray].resize(
318 caps.maxCombinedTextureImageUnits);
Jiajia Qin6eafb042016-12-27 17:04:07 +0800319
320 mAtomicCounterBuffers.resize(caps.maxAtomicCounterBufferBindings);
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800321 mShaderStorageBuffers.resize(caps.maxShaderStorageBufferBindings);
Xinghua Cao65ec0b22017-03-28 16:10:52 +0800322 mImageUnits.resize(caps.maxImageUnits);
Geoff Lang3b573612016-10-31 14:08:10 -0400323 }
Geoff Lang4751aab2017-10-30 15:14:52 -0400324 if (nativeExtensions.textureRectangle)
Corentin Wallez13c0dd42017-07-04 18:27:01 -0400325 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800326 mSamplerTextures[TextureType::Rectangle].resize(caps.maxCombinedTextureImageUnits);
Corentin Wallez13c0dd42017-07-04 18:27:01 -0400327 }
Geoff Lang4751aab2017-10-30 15:14:52 -0400328 if (nativeExtensions.eglImageExternal || nativeExtensions.eglStreamConsumerExternal)
Ian Ewellbda75592016-04-18 17:25:54 -0400329 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800330 mSamplerTextures[TextureType::External].resize(caps.maxCombinedTextureImageUnits);
Ian Ewellbda75592016-04-18 17:25:54 -0400331 }
Jamie Madill81c2e252017-09-09 23:32:46 -0400332 mCompleteTextureBindings.reserve(caps.maxCombinedTextureImageUnits);
Yizhou Jiang7818a852018-09-06 15:02:04 +0800333 mCachedTexturesInitState = InitState::MayNeedInit;
Qin Jiajia47f6dd02018-08-10 13:36:32 +0800334 mCachedImageTexturesInitState = InitState::MayNeedInit;
Jamie Madill81c2e252017-09-09 23:32:46 -0400335 for (uint32_t textureIndex = 0; textureIndex < caps.maxCombinedTextureImageUnits;
336 ++textureIndex)
337 {
Jamie Madill6c43a012018-08-08 15:49:27 -0400338 mCompleteTextureBindings.emplace_back(context, textureIndex);
Jamie Madill81c2e252017-09-09 23:32:46 -0400339 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400340
Geoff Lang76b10c92014-09-05 16:28:14 -0400341 mSamplers.resize(caps.maxCombinedTextureImageUnits);
Shannon Woods53a94a82014-06-24 15:20:36 -0400342
Corentin Wallezad3ae902018-03-09 13:40:42 -0500343 for (QueryType type : angle::AllEnums<QueryType>())
344 {
345 mActiveQueries[type].set(context, nullptr);
346 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400347
Ian Ewell3ffd78b2016-01-22 16:09:42 -0500348 mProgram = nullptr;
Shannon Woods53a94a82014-06-24 15:20:36 -0400349
Ian Ewell3ffd78b2016-01-22 16:09:42 -0500350 mReadFramebuffer = nullptr;
351 mDrawFramebuffer = nullptr;
Jamie Madillb4b53c52015-02-03 15:22:48 -0500352
353 mPrimitiveRestart = false;
Geoff Lang70d0f492015-12-10 17:45:46 -0500354
Geoff Lang70d0f492015-12-10 17:45:46 -0500355 mDebug.setMaxLoggedMessages(extensions.maxDebugLoggedMessages);
Sami Väisänen74c23472016-05-09 17:30:30 +0300356
Geoff Lang488130e2017-09-27 13:53:11 -0400357 mMultiSampling = true;
358 mSampleAlphaToOne = false;
Sami Väisänena797e062016-05-12 15:23:40 +0300359
360 mCoverageModulation = GL_NONE;
Sami Väisänene45e53b2016-05-25 10:36:04 +0300361
362 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixProj);
363 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixMV);
364 mPathStencilFunc = GL_ALWAYS;
365 mPathStencilRef = 0;
366 mPathStencilMask = std::numeric_limits<GLuint>::max();
Jamie Madille08a1d32017-03-07 17:24:06 -0500367
Lingfeng Yangdbb9c532018-02-25 19:58:24 -0800368 // GLES1 emulation: Initialize state for GLES1 if version
369 // applies
370 if (clientVersion < Version(2, 0))
371 {
Lingfeng Yange547aac2018-04-05 09:39:20 -0700372 mGLES1State.initialize(context, this);
Lingfeng Yangdbb9c532018-02-25 19:58:24 -0800373 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400374}
375
Jamie Madill6c1f6712017-02-14 19:08:04 -0500376void State::reset(const Context *context)
Shannon Woods53a94a82014-06-24 15:20:36 -0400377{
Jamie Madill8693bdb2017-09-02 15:32:14 -0400378 for (auto &bindingVec : mSamplerTextures)
Shannon Woods53a94a82014-06-24 15:20:36 -0400379 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800380 for (size_t textureIdx = 0; textureIdx < bindingVec.size(); textureIdx++)
Shannon Woods53a94a82014-06-24 15:20:36 -0400381 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800382 bindingVec[textureIdx].set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400383 }
384 }
Geoff Lang76b10c92014-09-05 16:28:14 -0400385 for (size_t samplerIdx = 0; samplerIdx < mSamplers.size(); samplerIdx++)
386 {
Jamie Madill4928b7c2017-06-20 12:57:39 -0400387 mSamplers[samplerIdx].set(context, nullptr);
Geoff Lang76b10c92014-09-05 16:28:14 -0400388 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400389
Xinghua Cao65ec0b22017-03-28 16:10:52 +0800390 for (auto &imageUnit : mImageUnits)
391 {
392 imageUnit.texture.set(context, nullptr);
393 imageUnit.level = 0;
394 imageUnit.layered = false;
395 imageUnit.layer = 0;
396 imageUnit.access = GL_READ_ONLY;
397 imageUnit.format = GL_R32UI;
398 }
399
Jamie Madill4928b7c2017-06-20 12:57:39 -0400400 mRenderbuffer.set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400401
Corentin Wallez336129f2017-10-17 15:55:40 -0400402 for (auto type : angle::AllEnums<BufferBinding>())
403 {
Jamie Madillbf5177d2018-08-21 12:58:20 -0400404 UpdateBufferBinding(context, &mBoundBuffers[type], nullptr, type);
Corentin Wallez336129f2017-10-17 15:55:40 -0400405 }
406
Geoff Lang7dd2e102014-11-10 15:19:26 -0500407 if (mProgram)
408 {
Jamie Madill6c1f6712017-02-14 19:08:04 -0500409 mProgram->release(context);
Geoff Lang7dd2e102014-11-10 15:19:26 -0500410 }
Yunchao Hed7297bf2017-04-19 15:27:10 +0800411 mProgram = nullptr;
Geoff Lang7dd2e102014-11-10 15:19:26 -0500412
Yunchao Hea336b902017-08-02 16:05:21 +0800413 mProgramPipeline.set(context, nullptr);
414
James Darpiniane8a93c62018-01-04 18:02:24 -0800415 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -0400416 mTransformFeedback->onBindingChanged(context, false);
Jamie Madill4928b7c2017-06-20 12:57:39 -0400417 mTransformFeedback.set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400418
Corentin Wallezad3ae902018-03-09 13:40:42 -0500419 for (QueryType type : angle::AllEnums<QueryType>())
Shannon Woods53a94a82014-06-24 15:20:36 -0400420 {
Corentin Wallezad3ae902018-03-09 13:40:42 -0500421 mActiveQueries[type].set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400422 }
423
Corentin Wallez336129f2017-10-17 15:55:40 -0400424 for (auto &buf : mUniformBuffers)
Shannon Woods53a94a82014-06-24 15:20:36 -0400425 {
Jamie Madillbf5177d2018-08-21 12:58:20 -0400426 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::Uniform, 0, 0);
Shannon Woods53a94a82014-06-24 15:20:36 -0400427 }
428
Jiajia Qin6eafb042016-12-27 17:04:07 +0800429 for (auto &buf : mAtomicCounterBuffers)
430 {
Jamie Madillbf5177d2018-08-21 12:58:20 -0400431 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::AtomicCounter, 0, 0);
Jiajia Qin6eafb042016-12-27 17:04:07 +0800432 }
433
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800434 for (auto &buf : mShaderStorageBuffers)
435 {
Jamie Madillbf5177d2018-08-21 12:58:20 -0400436 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::ShaderStorage, 0, 0);
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800437 }
438
Sami Väisänene45e53b2016-05-25 10:36:04 +0300439 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixProj);
440 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixMV);
441 mPathStencilFunc = GL_ALWAYS;
442 mPathStencilRef = 0;
443 mPathStencilMask = std::numeric_limits<GLuint>::max();
444
Jamie Madill1b94d432015-08-07 13:23:23 -0400445 setAllDirtyBits();
Shannon Woods53a94a82014-06-24 15:20:36 -0400446}
447
Jamie Madille3bb6b72018-10-03 17:51:15 -0400448ANGLE_INLINE void State::unsetActiveTextures(ActiveTextureMask textureMask)
449{
450 // Unset any relevant bound textures.
451 for (size_t textureIndex : mProgram->getActiveSamplersMask())
452 {
453 mActiveTexturesCache[textureIndex] = nullptr;
454 mCompleteTextureBindings[textureIndex].reset();
455 }
456}
457
Jamie Madille3e680c2018-12-03 17:49:08 -0500458ANGLE_INLINE void State::updateActiveTextureState(const Context *context,
459 size_t textureIndex,
460 const Sampler *sampler,
461 Texture *texture)
462{
463 if (!texture->isSamplerComplete(context, sampler))
464 {
465 mActiveTexturesCache[textureIndex] = nullptr;
466 }
467 else
468 {
469 mActiveTexturesCache[textureIndex] = texture;
470
471 if (texture->hasAnyDirtyBit())
472 {
473 setTextureDirty(textureIndex);
474 }
475
476 if (texture->initState() == InitState::MayNeedInit)
477 {
478 mCachedTexturesInitState = InitState::MayNeedInit;
479 }
480 }
481
482 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
483}
484
485ANGLE_INLINE void State::updateActiveTexture(const Context *context,
486 size_t textureIndex,
487 Texture *texture)
Jamie Madille3bb6b72018-10-03 17:51:15 -0400488{
489 const Sampler *sampler = mSamplers[textureIndex].get();
490
Jamie Madille3e680c2018-12-03 17:49:08 -0500491 mCompleteTextureBindings[textureIndex].bind(texture);
492
Jamie Madille3bb6b72018-10-03 17:51:15 -0400493 if (!texture)
494 {
495 mActiveTexturesCache[textureIndex] = nullptr;
Jamie Madille3e680c2018-12-03 17:49:08 -0500496 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
497 return;
Jamie Madille3bb6b72018-10-03 17:51:15 -0400498 }
499
Jamie Madille3e680c2018-12-03 17:49:08 -0500500 updateActiveTextureState(context, textureIndex, sampler, texture);
Jamie Madille3bb6b72018-10-03 17:51:15 -0400501}
502
Shannon Woods53a94a82014-06-24 15:20:36 -0400503const RasterizerState &State::getRasterizerState() const
504{
505 return mRasterizer;
506}
507
508const BlendState &State::getBlendState() const
509{
510 return mBlend;
511}
512
513const DepthStencilState &State::getDepthStencilState() const
514{
515 return mDepthStencil;
516}
517
Jamie Madillf75ab352015-03-16 10:46:52 -0400518void State::setColorClearValue(float red, float green, float blue, float alpha)
Shannon Woods53a94a82014-06-24 15:20:36 -0400519{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700520 mColorClearValue.red = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400521 mColorClearValue.green = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700522 mColorClearValue.blue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400523 mColorClearValue.alpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400524 mDirtyBits.set(DIRTY_BIT_CLEAR_COLOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400525}
526
Jamie Madillf75ab352015-03-16 10:46:52 -0400527void State::setDepthClearValue(float depth)
Shannon Woods53a94a82014-06-24 15:20:36 -0400528{
529 mDepthClearValue = depth;
Jamie Madill1b94d432015-08-07 13:23:23 -0400530 mDirtyBits.set(DIRTY_BIT_CLEAR_DEPTH);
Shannon Woods53a94a82014-06-24 15:20:36 -0400531}
532
Jamie Madillf75ab352015-03-16 10:46:52 -0400533void State::setStencilClearValue(int stencil)
Shannon Woods53a94a82014-06-24 15:20:36 -0400534{
535 mStencilClearValue = stencil;
Jamie Madill1b94d432015-08-07 13:23:23 -0400536 mDirtyBits.set(DIRTY_BIT_CLEAR_STENCIL);
Shannon Woods53a94a82014-06-24 15:20:36 -0400537}
538
Shannon Woods53a94a82014-06-24 15:20:36 -0400539void State::setColorMask(bool red, bool green, bool blue, bool alpha)
540{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700541 mBlend.colorMaskRed = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400542 mBlend.colorMaskGreen = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700543 mBlend.colorMaskBlue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400544 mBlend.colorMaskAlpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400545 mDirtyBits.set(DIRTY_BIT_COLOR_MASK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400546}
547
548void State::setDepthMask(bool mask)
549{
550 mDepthStencil.depthMask = mask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400551 mDirtyBits.set(DIRTY_BIT_DEPTH_MASK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400552}
553
Shannon Woods53a94a82014-06-24 15:20:36 -0400554void State::setRasterizerDiscard(bool enabled)
555{
556 mRasterizer.rasterizerDiscard = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400557 mDirtyBits.set(DIRTY_BIT_RASTERIZER_DISCARD_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400558}
559
Shannon Woods53a94a82014-06-24 15:20:36 -0400560void State::setCullFace(bool enabled)
561{
562 mRasterizer.cullFace = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400563 mDirtyBits.set(DIRTY_BIT_CULL_FACE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400564}
565
Corentin Wallez2e568cf2017-09-18 17:05:22 -0400566void State::setCullMode(CullFaceMode mode)
Shannon Woods53a94a82014-06-24 15:20:36 -0400567{
568 mRasterizer.cullMode = mode;
Jamie Madill1b94d432015-08-07 13:23:23 -0400569 mDirtyBits.set(DIRTY_BIT_CULL_FACE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400570}
571
572void State::setFrontFace(GLenum front)
573{
574 mRasterizer.frontFace = front;
Jamie Madill1b94d432015-08-07 13:23:23 -0400575 mDirtyBits.set(DIRTY_BIT_FRONT_FACE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400576}
577
Shannon Woods53a94a82014-06-24 15:20:36 -0400578void State::setDepthTest(bool enabled)
579{
580 mDepthStencil.depthTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400581 mDirtyBits.set(DIRTY_BIT_DEPTH_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400582}
583
584void State::setDepthFunc(GLenum depthFunc)
585{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700586 mDepthStencil.depthFunc = depthFunc;
587 mDirtyBits.set(DIRTY_BIT_DEPTH_FUNC);
Shannon Woods53a94a82014-06-24 15:20:36 -0400588}
589
590void State::setDepthRange(float zNear, float zFar)
591{
592 mNearZ = zNear;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700593 mFarZ = zFar;
Jamie Madill1b94d432015-08-07 13:23:23 -0400594 mDirtyBits.set(DIRTY_BIT_DEPTH_RANGE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400595}
596
Shannon Woods53a94a82014-06-24 15:20:36 -0400597void State::setBlend(bool enabled)
598{
599 mBlend.blend = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400600 mDirtyBits.set(DIRTY_BIT_BLEND_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400601}
602
603void State::setBlendFactors(GLenum sourceRGB, GLenum destRGB, GLenum sourceAlpha, GLenum destAlpha)
604{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700605 mBlend.sourceBlendRGB = sourceRGB;
606 mBlend.destBlendRGB = destRGB;
Shannon Woods53a94a82014-06-24 15:20:36 -0400607 mBlend.sourceBlendAlpha = sourceAlpha;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700608 mBlend.destBlendAlpha = destAlpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400609 mDirtyBits.set(DIRTY_BIT_BLEND_FUNCS);
Shannon Woods53a94a82014-06-24 15:20:36 -0400610}
611
612void State::setBlendColor(float red, float green, float blue, float alpha)
613{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700614 mBlendColor.red = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400615 mBlendColor.green = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700616 mBlendColor.blue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400617 mBlendColor.alpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400618 mDirtyBits.set(DIRTY_BIT_BLEND_COLOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400619}
620
621void State::setBlendEquation(GLenum rgbEquation, GLenum alphaEquation)
622{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700623 mBlend.blendEquationRGB = rgbEquation;
Shannon Woods53a94a82014-06-24 15:20:36 -0400624 mBlend.blendEquationAlpha = alphaEquation;
Jamie Madill1b94d432015-08-07 13:23:23 -0400625 mDirtyBits.set(DIRTY_BIT_BLEND_EQUATIONS);
Shannon Woods53a94a82014-06-24 15:20:36 -0400626}
627
Shannon Woods53a94a82014-06-24 15:20:36 -0400628void State::setStencilTest(bool enabled)
629{
630 mDepthStencil.stencilTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400631 mDirtyBits.set(DIRTY_BIT_STENCIL_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400632}
633
634void State::setStencilParams(GLenum stencilFunc, GLint stencilRef, GLuint stencilMask)
635{
636 mDepthStencil.stencilFunc = stencilFunc;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700637 mStencilRef = (stencilRef > 0) ? stencilRef : 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400638 mDepthStencil.stencilMask = stencilMask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400639 mDirtyBits.set(DIRTY_BIT_STENCIL_FUNCS_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400640}
641
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700642void State::setStencilBackParams(GLenum stencilBackFunc,
643 GLint stencilBackRef,
644 GLuint stencilBackMask)
Shannon Woods53a94a82014-06-24 15:20:36 -0400645{
646 mDepthStencil.stencilBackFunc = stencilBackFunc;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700647 mStencilBackRef = (stencilBackRef > 0) ? stencilBackRef : 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400648 mDepthStencil.stencilBackMask = stencilBackMask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400649 mDirtyBits.set(DIRTY_BIT_STENCIL_FUNCS_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400650}
651
652void State::setStencilWritemask(GLuint stencilWritemask)
653{
654 mDepthStencil.stencilWritemask = stencilWritemask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400655 mDirtyBits.set(DIRTY_BIT_STENCIL_WRITEMASK_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400656}
657
658void State::setStencilBackWritemask(GLuint stencilBackWritemask)
659{
660 mDepthStencil.stencilBackWritemask = stencilBackWritemask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400661 mDirtyBits.set(DIRTY_BIT_STENCIL_WRITEMASK_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400662}
663
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700664void State::setStencilOperations(GLenum stencilFail,
665 GLenum stencilPassDepthFail,
666 GLenum stencilPassDepthPass)
Shannon Woods53a94a82014-06-24 15:20:36 -0400667{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700668 mDepthStencil.stencilFail = stencilFail;
Shannon Woods53a94a82014-06-24 15:20:36 -0400669 mDepthStencil.stencilPassDepthFail = stencilPassDepthFail;
670 mDepthStencil.stencilPassDepthPass = stencilPassDepthPass;
Jamie Madill1b94d432015-08-07 13:23:23 -0400671 mDirtyBits.set(DIRTY_BIT_STENCIL_OPS_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400672}
673
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700674void State::setStencilBackOperations(GLenum stencilBackFail,
675 GLenum stencilBackPassDepthFail,
676 GLenum stencilBackPassDepthPass)
Shannon Woods53a94a82014-06-24 15:20:36 -0400677{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700678 mDepthStencil.stencilBackFail = stencilBackFail;
Shannon Woods53a94a82014-06-24 15:20:36 -0400679 mDepthStencil.stencilBackPassDepthFail = stencilBackPassDepthFail;
680 mDepthStencil.stencilBackPassDepthPass = stencilBackPassDepthPass;
Jamie Madill1b94d432015-08-07 13:23:23 -0400681 mDirtyBits.set(DIRTY_BIT_STENCIL_OPS_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400682}
683
Shannon Woods53a94a82014-06-24 15:20:36 -0400684void State::setPolygonOffsetFill(bool enabled)
685{
Jamie Madill1b94d432015-08-07 13:23:23 -0400686 mRasterizer.polygonOffsetFill = enabled;
687 mDirtyBits.set(DIRTY_BIT_POLYGON_OFFSET_FILL_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400688}
689
690void State::setPolygonOffsetParams(GLfloat factor, GLfloat units)
691{
692 // An application can pass NaN values here, so handle this gracefully
693 mRasterizer.polygonOffsetFactor = factor != factor ? 0.0f : factor;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700694 mRasterizer.polygonOffsetUnits = units != units ? 0.0f : units;
Jamie Madill1b94d432015-08-07 13:23:23 -0400695 mDirtyBits.set(DIRTY_BIT_POLYGON_OFFSET);
Shannon Woods53a94a82014-06-24 15:20:36 -0400696}
697
Shannon Woods53a94a82014-06-24 15:20:36 -0400698void State::setSampleAlphaToCoverage(bool enabled)
699{
700 mBlend.sampleAlphaToCoverage = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400701 mDirtyBits.set(DIRTY_BIT_SAMPLE_ALPHA_TO_COVERAGE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400702}
703
Shannon Woods53a94a82014-06-24 15:20:36 -0400704void State::setSampleCoverage(bool enabled)
705{
706 mSampleCoverage = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400707 mDirtyBits.set(DIRTY_BIT_SAMPLE_COVERAGE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400708}
709
710void State::setSampleCoverageParams(GLclampf value, bool invert)
711{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700712 mSampleCoverageValue = value;
Shannon Woods53a94a82014-06-24 15:20:36 -0400713 mSampleCoverageInvert = invert;
Jamie Madill1b94d432015-08-07 13:23:23 -0400714 mDirtyBits.set(DIRTY_BIT_SAMPLE_COVERAGE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400715}
716
Jiawei Shaodb342272017-09-27 10:21:45 +0800717void State::setSampleMaskEnabled(bool enabled)
718{
719 mSampleMask = enabled;
720 mDirtyBits.set(DIRTY_BIT_SAMPLE_MASK_ENABLED);
721}
722
723void State::setSampleMaskParams(GLuint maskNumber, GLbitfield mask)
724{
725 ASSERT(maskNumber < mMaxSampleMaskWords);
726 mSampleMaskValues[maskNumber] = mask;
Jamie Madillc67323a2017-11-02 23:11:41 -0400727 // TODO(jmadill): Use a child dirty bit if we ever use more than two words.
728 mDirtyBits.set(DIRTY_BIT_SAMPLE_MASK);
Jiawei Shaodb342272017-09-27 10:21:45 +0800729}
730
Sami Väisänen74c23472016-05-09 17:30:30 +0300731void State::setSampleAlphaToOne(bool enabled)
732{
733 mSampleAlphaToOne = enabled;
734 mDirtyBits.set(DIRTY_BIT_SAMPLE_ALPHA_TO_ONE);
735}
736
Sami Väisänen74c23472016-05-09 17:30:30 +0300737void State::setMultisampling(bool enabled)
738{
739 mMultiSampling = enabled;
740 mDirtyBits.set(DIRTY_BIT_MULTISAMPLING);
741}
742
Shannon Woods53a94a82014-06-24 15:20:36 -0400743void State::setScissorTest(bool enabled)
744{
745 mScissorTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400746 mDirtyBits.set(DIRTY_BIT_SCISSOR_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400747}
748
749void State::setScissorParams(GLint x, GLint y, GLsizei width, GLsizei height)
750{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700751 mScissor.x = x;
752 mScissor.y = y;
753 mScissor.width = width;
Shannon Woods53a94a82014-06-24 15:20:36 -0400754 mScissor.height = height;
Jamie Madill1b94d432015-08-07 13:23:23 -0400755 mDirtyBits.set(DIRTY_BIT_SCISSOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400756}
757
Shannon Woods53a94a82014-06-24 15:20:36 -0400758void State::setDither(bool enabled)
759{
760 mBlend.dither = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400761 mDirtyBits.set(DIRTY_BIT_DITHER_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400762}
763
Jamie Madillb4b53c52015-02-03 15:22:48 -0500764void State::setPrimitiveRestart(bool enabled)
765{
766 mPrimitiveRestart = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400767 mDirtyBits.set(DIRTY_BIT_PRIMITIVE_RESTART_ENABLED);
Jamie Madillb4b53c52015-02-03 15:22:48 -0500768}
769
Shannon Woods53a94a82014-06-24 15:20:36 -0400770void State::setEnableFeature(GLenum feature, bool enabled)
771{
772 switch (feature)
773 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700774 case GL_MULTISAMPLE_EXT:
775 setMultisampling(enabled);
776 break;
777 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
778 setSampleAlphaToOne(enabled);
779 break;
780 case GL_CULL_FACE:
781 setCullFace(enabled);
782 break;
783 case GL_POLYGON_OFFSET_FILL:
784 setPolygonOffsetFill(enabled);
785 break;
786 case GL_SAMPLE_ALPHA_TO_COVERAGE:
787 setSampleAlphaToCoverage(enabled);
788 break;
789 case GL_SAMPLE_COVERAGE:
790 setSampleCoverage(enabled);
791 break;
792 case GL_SCISSOR_TEST:
793 setScissorTest(enabled);
794 break;
795 case GL_STENCIL_TEST:
796 setStencilTest(enabled);
797 break;
798 case GL_DEPTH_TEST:
799 setDepthTest(enabled);
800 break;
801 case GL_BLEND:
802 setBlend(enabled);
803 break;
804 case GL_DITHER:
805 setDither(enabled);
806 break;
807 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
808 setPrimitiveRestart(enabled);
809 break;
810 case GL_RASTERIZER_DISCARD:
811 setRasterizerDiscard(enabled);
812 break;
813 case GL_SAMPLE_MASK:
814 setSampleMaskEnabled(enabled);
815 break;
816 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
817 mDebug.setOutputSynchronous(enabled);
818 break;
819 case GL_DEBUG_OUTPUT:
820 mDebug.setOutputEnabled(enabled);
821 break;
822 case GL_FRAMEBUFFER_SRGB_EXT:
823 setFramebufferSRGB(enabled);
824 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -0700825
826 // GLES1 emulation
827 case GL_ALPHA_TEST:
828 mGLES1State.mAlphaTestEnabled = enabled;
829 break;
Lingfeng Yang23dc90b2018-04-23 09:01:49 -0700830 case GL_TEXTURE_2D:
831 mGLES1State.mTexUnitEnables[mActiveSampler].set(TextureType::_2D, enabled);
832 break;
833 case GL_TEXTURE_CUBE_MAP:
834 mGLES1State.mTexUnitEnables[mActiveSampler].set(TextureType::CubeMap, enabled);
835 break;
Lingfeng Yangd0febe72018-05-17 22:36:52 -0700836 case GL_LIGHTING:
837 mGLES1State.mLightingEnabled = enabled;
838 break;
839 case GL_LIGHT0:
840 case GL_LIGHT1:
841 case GL_LIGHT2:
842 case GL_LIGHT3:
843 case GL_LIGHT4:
844 case GL_LIGHT5:
845 case GL_LIGHT6:
846 case GL_LIGHT7:
847 mGLES1State.mLights[feature - GL_LIGHT0].enabled = enabled;
848 break;
849 case GL_NORMALIZE:
850 mGLES1State.mNormalizeEnabled = enabled;
851 break;
852 case GL_RESCALE_NORMAL:
853 mGLES1State.mRescaleNormalEnabled = enabled;
854 break;
855 case GL_COLOR_MATERIAL:
856 mGLES1State.mColorMaterialEnabled = enabled;
857 break;
Lingfeng Yang060088a2018-05-30 20:40:57 -0700858 case GL_CLIP_PLANE0:
859 case GL_CLIP_PLANE1:
860 case GL_CLIP_PLANE2:
861 case GL_CLIP_PLANE3:
862 case GL_CLIP_PLANE4:
863 case GL_CLIP_PLANE5:
864 mGLES1State.mClipPlanes[feature - GL_CLIP_PLANE0].enabled = enabled;
865 break;
Lingfeng Yang7ba3f422018-06-01 09:43:04 -0700866 case GL_FOG:
867 mGLES1State.mFogEnabled = enabled;
868 break;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -0700869 case GL_POINT_SMOOTH:
870 mGLES1State.mPointSmoothEnabled = enabled;
871 break;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -0700872 case GL_LINE_SMOOTH:
873 mGLES1State.mLineSmoothEnabled = enabled;
874 break;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -0700875 case GL_POINT_SPRITE_OES:
876 mGLES1State.mPointSpriteEnabled = enabled;
877 break;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -0700878 case GL_COLOR_LOGIC_OP:
879 mGLES1State.mLogicOpEnabled = enabled;
880 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700881 default:
882 UNREACHABLE();
Shannon Woods53a94a82014-06-24 15:20:36 -0400883 }
884}
885
Jamie Madilldfde6ab2016-06-09 07:07:18 -0700886bool State::getEnableFeature(GLenum feature) const
Shannon Woods53a94a82014-06-24 15:20:36 -0400887{
888 switch (feature)
889 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700890 case GL_MULTISAMPLE_EXT:
891 return isMultisamplingEnabled();
892 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
893 return isSampleAlphaToOneEnabled();
894 case GL_CULL_FACE:
895 return isCullFaceEnabled();
896 case GL_POLYGON_OFFSET_FILL:
897 return isPolygonOffsetFillEnabled();
898 case GL_SAMPLE_ALPHA_TO_COVERAGE:
899 return isSampleAlphaToCoverageEnabled();
900 case GL_SAMPLE_COVERAGE:
901 return isSampleCoverageEnabled();
902 case GL_SCISSOR_TEST:
903 return isScissorTestEnabled();
904 case GL_STENCIL_TEST:
905 return isStencilTestEnabled();
906 case GL_DEPTH_TEST:
907 return isDepthTestEnabled();
908 case GL_BLEND:
909 return isBlendEnabled();
910 case GL_DITHER:
911 return isDitherEnabled();
912 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
913 return isPrimitiveRestartEnabled();
914 case GL_RASTERIZER_DISCARD:
915 return isRasterizerDiscardEnabled();
916 case GL_SAMPLE_MASK:
917 return isSampleMaskEnabled();
918 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
919 return mDebug.isOutputSynchronous();
920 case GL_DEBUG_OUTPUT:
921 return mDebug.isOutputEnabled();
922 case GL_BIND_GENERATES_RESOURCE_CHROMIUM:
923 return isBindGeneratesResourceEnabled();
924 case GL_CLIENT_ARRAYS_ANGLE:
925 return areClientArraysEnabled();
926 case GL_FRAMEBUFFER_SRGB_EXT:
927 return getFramebufferSRGB();
928 case GL_ROBUST_RESOURCE_INITIALIZATION_ANGLE:
929 return mRobustResourceInit;
930 case GL_PROGRAM_CACHE_ENABLED_ANGLE:
931 return mProgramBinaryCacheEnabled;
Jamie Madillc43be722017-07-13 16:22:14 -0400932
Lingfeng Yang13b708f2018-03-21 12:14:10 -0700933 // GLES1 emulation
934 case GL_ALPHA_TEST:
935 return mGLES1State.mAlphaTestEnabled;
Lingfeng Yang01074432018-04-16 10:19:51 -0700936 case GL_VERTEX_ARRAY:
937 return mGLES1State.mVertexArrayEnabled;
938 case GL_NORMAL_ARRAY:
939 return mGLES1State.mNormalArrayEnabled;
940 case GL_COLOR_ARRAY:
941 return mGLES1State.mColorArrayEnabled;
942 case GL_POINT_SIZE_ARRAY_OES:
943 return mGLES1State.mPointSizeArrayEnabled;
944 case GL_TEXTURE_COORD_ARRAY:
945 return mGLES1State.mTexCoordArrayEnabled[mGLES1State.mClientActiveTexture];
Lingfeng Yang23dc90b2018-04-23 09:01:49 -0700946 case GL_TEXTURE_2D:
947 return mGLES1State.mTexUnitEnables[mActiveSampler].test(TextureType::_2D);
948 case GL_TEXTURE_CUBE_MAP:
949 return mGLES1State.mTexUnitEnables[mActiveSampler].test(TextureType::CubeMap);
Lingfeng Yangd0febe72018-05-17 22:36:52 -0700950 case GL_LIGHTING:
951 return mGLES1State.mLightingEnabled;
952 case GL_LIGHT0:
953 case GL_LIGHT1:
954 case GL_LIGHT2:
955 case GL_LIGHT3:
956 case GL_LIGHT4:
957 case GL_LIGHT5:
958 case GL_LIGHT6:
959 case GL_LIGHT7:
960 return mGLES1State.mLights[feature - GL_LIGHT0].enabled;
961 case GL_NORMALIZE:
962 return mGLES1State.mNormalizeEnabled;
963 case GL_RESCALE_NORMAL:
964 return mGLES1State.mRescaleNormalEnabled;
965 case GL_COLOR_MATERIAL:
966 return mGLES1State.mColorMaterialEnabled;
Lingfeng Yang060088a2018-05-30 20:40:57 -0700967 case GL_CLIP_PLANE0:
968 case GL_CLIP_PLANE1:
969 case GL_CLIP_PLANE2:
970 case GL_CLIP_PLANE3:
971 case GL_CLIP_PLANE4:
972 case GL_CLIP_PLANE5:
973 return mGLES1State.mClipPlanes[feature - GL_CLIP_PLANE0].enabled;
Lingfeng Yang7ba3f422018-06-01 09:43:04 -0700974 case GL_FOG:
975 return mGLES1State.mFogEnabled;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -0700976 case GL_POINT_SMOOTH:
977 return mGLES1State.mPointSmoothEnabled;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -0700978 case GL_LINE_SMOOTH:
979 return mGLES1State.mLineSmoothEnabled;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -0700980 case GL_POINT_SPRITE_OES:
981 return mGLES1State.mPointSpriteEnabled;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -0700982 case GL_COLOR_LOGIC_OP:
983 return mGLES1State.mLogicOpEnabled;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700984 default:
985 UNREACHABLE();
986 return false;
Shannon Woods53a94a82014-06-24 15:20:36 -0400987 }
988}
989
990void State::setLineWidth(GLfloat width)
991{
992 mLineWidth = width;
Jamie Madill1b94d432015-08-07 13:23:23 -0400993 mDirtyBits.set(DIRTY_BIT_LINE_WIDTH);
Shannon Woods53a94a82014-06-24 15:20:36 -0400994}
995
996void State::setGenerateMipmapHint(GLenum hint)
997{
998 mGenerateMipmapHint = hint;
Jamie Madill1b94d432015-08-07 13:23:23 -0400999 mDirtyBits.set(DIRTY_BIT_GENERATE_MIPMAP_HINT);
Shannon Woods53a94a82014-06-24 15:20:36 -04001000}
1001
1002void State::setFragmentShaderDerivativeHint(GLenum hint)
1003{
1004 mFragmentShaderDerivativeHint = hint;
Jamie Madill1b94d432015-08-07 13:23:23 -04001005 mDirtyBits.set(DIRTY_BIT_SHADER_DERIVATIVE_HINT);
Shannon Woods53a94a82014-06-24 15:20:36 -04001006 // TODO: Propagate the hint to shader translator so we can write
1007 // ddx, ddx_coarse, or ddx_fine depending on the hint.
1008 // Ignore for now. It is valid for implementations to ignore hint.
1009}
1010
1011void State::setViewportParams(GLint x, GLint y, GLsizei width, GLsizei height)
1012{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001013 mViewport.x = x;
1014 mViewport.y = y;
1015 mViewport.width = width;
Shannon Woods53a94a82014-06-24 15:20:36 -04001016 mViewport.height = height;
Jamie Madill1b94d432015-08-07 13:23:23 -04001017 mDirtyBits.set(DIRTY_BIT_VIEWPORT);
Shannon Woods53a94a82014-06-24 15:20:36 -04001018}
1019
Shannon Woods53a94a82014-06-24 15:20:36 -04001020void State::setActiveSampler(unsigned int active)
1021{
1022 mActiveSampler = active;
1023}
1024
Jamie Madille3e680c2018-12-03 17:49:08 -05001025void State::setSamplerTexture(const Context *context, TextureType type, Texture *texture)
Shannon Woods53a94a82014-06-24 15:20:36 -04001026{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001027 mSamplerTextures[type][mActiveSampler].set(context, texture);
Jamie Madill14246812018-10-03 17:51:16 -04001028
1029 if (mProgram && mProgram->getActiveSamplersMask()[mActiveSampler] &&
1030 mProgram->getActiveSamplerTypes()[mActiveSampler] == type)
1031 {
Jamie Madille3e680c2018-12-03 17:49:08 -05001032 updateActiveTexture(context, mActiveSampler, texture);
Jamie Madill14246812018-10-03 17:51:16 -04001033 }
1034
Jamie Madill81c2e252017-09-09 23:32:46 -04001035 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
Shannon Woods53a94a82014-06-24 15:20:36 -04001036}
1037
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001038Texture *State::getTargetTexture(TextureType type) const
Jamie Madillc29968b2016-01-20 11:17:23 -05001039{
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001040 return getSamplerTexture(static_cast<unsigned int>(mActiveSampler), type);
Jamie Madillc29968b2016-01-20 11:17:23 -05001041}
1042
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001043GLuint State::getSamplerTextureId(unsigned int sampler, TextureType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001044{
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001045 ASSERT(sampler < mSamplerTextures[type].size());
1046 return mSamplerTextures[type][sampler].id();
Shannon Woods53a94a82014-06-24 15:20:36 -04001047}
1048
Jamie Madilla02315b2017-02-23 14:14:47 -05001049void State::detachTexture(const Context *context, const TextureMap &zeroTextures, GLuint texture)
Shannon Woods53a94a82014-06-24 15:20:36 -04001050{
1051 // Textures have a detach method on State rather than a simple
1052 // removeBinding, because the zero/null texture objects are managed
1053 // separately, and don't have to go through the Context's maps or
1054 // the ResourceManager.
1055
1056 // [OpenGL ES 2.0.24] section 3.8 page 84:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001057 // If a texture object is deleted, it is as if all texture units which are bound to that texture
1058 // object are rebound to texture object zero
Shannon Woods53a94a82014-06-24 15:20:36 -04001059
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001060 for (TextureType type : angle::AllEnums<TextureType>())
Shannon Woods53a94a82014-06-24 15:20:36 -04001061 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001062 TextureBindingVector &textureVector = mSamplerTextures[type];
Jamie Madill81c2e252017-09-09 23:32:46 -04001063 for (BindingPointer<Texture> &binding : textureVector)
Shannon Woods53a94a82014-06-24 15:20:36 -04001064 {
Geoff Lang76b10c92014-09-05 16:28:14 -04001065 if (binding.id() == texture)
Shannon Woods53a94a82014-06-24 15:20:36 -04001066 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001067 Texture *zeroTexture = zeroTextures[type].get();
1068 ASSERT(zeroTexture != nullptr);
Jamie Madille6382c32014-11-07 15:05:26 -05001069 // Zero textures are the "default" textures instead of NULL
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001070 binding.set(context, zeroTexture);
Jamie Madill81c2e252017-09-09 23:32:46 -04001071 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
Shannon Woods53a94a82014-06-24 15:20:36 -04001072 }
1073 }
1074 }
1075
Xinghua Cao65ec0b22017-03-28 16:10:52 +08001076 for (auto &bindingImageUnit : mImageUnits)
1077 {
1078 if (bindingImageUnit.texture.id() == texture)
1079 {
1080 bindingImageUnit.texture.set(context, nullptr);
1081 bindingImageUnit.level = 0;
1082 bindingImageUnit.layered = false;
1083 bindingImageUnit.layer = 0;
1084 bindingImageUnit.access = GL_READ_ONLY;
1085 bindingImageUnit.format = GL_R32UI;
1086 break;
1087 }
1088 }
1089
Shannon Woods53a94a82014-06-24 15:20:36 -04001090 // [OpenGL ES 2.0.24] section 4.4 page 112:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001091 // If a texture object is deleted while its image is attached to the currently bound
1092 // framebuffer, then it is as if Texture2DAttachment had been called, with a texture of 0, for
1093 // each attachment point to which this image was attached in the currently bound framebuffer.
Shannon Woods53a94a82014-06-24 15:20:36 -04001094
Jamie Madill8693bdb2017-09-02 15:32:14 -04001095 if (mReadFramebuffer && mReadFramebuffer->detachTexture(context, texture))
Shannon Woods53a94a82014-06-24 15:20:36 -04001096 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001097 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
Shannon Woods53a94a82014-06-24 15:20:36 -04001098 }
1099
Jamie Madill8693bdb2017-09-02 15:32:14 -04001100 if (mDrawFramebuffer && mDrawFramebuffer->detachTexture(context, texture))
Shannon Woods53a94a82014-06-24 15:20:36 -04001101 {
Jamie Madillef9fcd92018-11-28 14:03:59 -05001102 setDrawFramebufferDirty();
Shannon Woods53a94a82014-06-24 15:20:36 -04001103 }
1104}
1105
Jamie Madill4928b7c2017-06-20 12:57:39 -04001106void State::initializeZeroTextures(const Context *context, const TextureMap &zeroTextures)
Jamie Madille6382c32014-11-07 15:05:26 -05001107{
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001108 for (TextureType type : angle::AllEnums<TextureType>())
Jamie Madille6382c32014-11-07 15:05:26 -05001109 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001110 for (size_t textureUnit = 0; textureUnit < mSamplerTextures[type].size(); ++textureUnit)
Jamie Madille6382c32014-11-07 15:05:26 -05001111 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001112 mSamplerTextures[type][textureUnit].set(context, zeroTextures[type].get());
Jamie Madille6382c32014-11-07 15:05:26 -05001113 }
1114 }
1115}
1116
Jamie Madill4928b7c2017-06-20 12:57:39 -04001117void State::setSamplerBinding(const Context *context, GLuint textureUnit, Sampler *sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001118{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001119 mSamplers[textureUnit].set(context, sampler);
Jamie Madill81c2e252017-09-09 23:32:46 -04001120 mDirtyBits.set(DIRTY_BIT_SAMPLER_BINDINGS);
Jamie Madille25b8002018-09-20 13:39:49 -04001121 // This is overly conservative as it assumes the sampler has never been bound.
1122 setSamplerDirty(textureUnit);
Jamie Madille3e680c2018-12-03 17:49:08 -05001123 onActiveTextureChange(context, textureUnit);
Shannon Woods53a94a82014-06-24 15:20:36 -04001124}
1125
Jamie Madill4928b7c2017-06-20 12:57:39 -04001126void State::detachSampler(const Context *context, GLuint sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001127{
1128 // [OpenGL ES 3.0.2] section 3.8.2 pages 123-124:
1129 // If a sampler object that is currently bound to one or more texture units is
1130 // deleted, it is as though BindSampler is called once for each texture unit to
1131 // which the sampler is bound, with unit set to the texture unit and sampler set to zero.
Jamie Madill81c2e252017-09-09 23:32:46 -04001132 for (BindingPointer<Sampler> &samplerBinding : mSamplers)
Shannon Woods53a94a82014-06-24 15:20:36 -04001133 {
Geoff Lang76b10c92014-09-05 16:28:14 -04001134 if (samplerBinding.id() == sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001135 {
Jamie Madill4928b7c2017-06-20 12:57:39 -04001136 samplerBinding.set(context, nullptr);
Jamie Madill81c2e252017-09-09 23:32:46 -04001137 mDirtyBits.set(DIRTY_BIT_SAMPLER_BINDINGS);
Shannon Woods53a94a82014-06-24 15:20:36 -04001138 }
1139 }
1140}
1141
Jamie Madill4928b7c2017-06-20 12:57:39 -04001142void State::setRenderbufferBinding(const Context *context, Renderbuffer *renderbuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001143{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001144 mRenderbuffer.set(context, renderbuffer);
Jamie Madill8693bdb2017-09-02 15:32:14 -04001145 mDirtyBits.set(DIRTY_BIT_RENDERBUFFER_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001146}
1147
Jamie Madilla02315b2017-02-23 14:14:47 -05001148void State::detachRenderbuffer(const Context *context, GLuint renderbuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001149{
1150 // [OpenGL ES 2.0.24] section 4.4 page 109:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001151 // If a renderbuffer that is currently bound to RENDERBUFFER is deleted, it is as though
1152 // BindRenderbuffer had been executed with the target RENDERBUFFER and name of zero.
Shannon Woods53a94a82014-06-24 15:20:36 -04001153
1154 if (mRenderbuffer.id() == renderbuffer)
1155 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001156 setRenderbufferBinding(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001157 }
1158
1159 // [OpenGL ES 2.0.24] section 4.4 page 111:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001160 // If a renderbuffer object is deleted while its image is attached to the currently bound
1161 // framebuffer, then it is as if FramebufferRenderbuffer had been called, with a renderbuffer of
1162 // 0, for each attachment point to which this image was attached in the currently bound
1163 // framebuffer.
Shannon Woods53a94a82014-06-24 15:20:36 -04001164
1165 Framebuffer *readFramebuffer = mReadFramebuffer;
1166 Framebuffer *drawFramebuffer = mDrawFramebuffer;
1167
Jamie Madill8693bdb2017-09-02 15:32:14 -04001168 if (readFramebuffer && readFramebuffer->detachRenderbuffer(context, renderbuffer))
Shannon Woods53a94a82014-06-24 15:20:36 -04001169 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001170 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
Shannon Woods53a94a82014-06-24 15:20:36 -04001171 }
1172
1173 if (drawFramebuffer && drawFramebuffer != readFramebuffer)
1174 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001175 if (drawFramebuffer->detachRenderbuffer(context, renderbuffer))
1176 {
Jamie Madillef9fcd92018-11-28 14:03:59 -05001177 setDrawFramebufferDirty();
Jamie Madill8693bdb2017-09-02 15:32:14 -04001178 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001179 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001180}
1181
1182void State::setReadFramebufferBinding(Framebuffer *framebuffer)
1183{
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001184 if (mReadFramebuffer == framebuffer)
1185 return;
1186
Shannon Woods53a94a82014-06-24 15:20:36 -04001187 mReadFramebuffer = framebuffer;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001188 mDirtyBits.set(DIRTY_BIT_READ_FRAMEBUFFER_BINDING);
1189
1190 if (mReadFramebuffer && mReadFramebuffer->hasAnyDirtyBit())
1191 {
1192 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
1193 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001194}
1195
1196void State::setDrawFramebufferBinding(Framebuffer *framebuffer)
1197{
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001198 if (mDrawFramebuffer == framebuffer)
1199 return;
1200
Shannon Woods53a94a82014-06-24 15:20:36 -04001201 mDrawFramebuffer = framebuffer;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001202 mDirtyBits.set(DIRTY_BIT_DRAW_FRAMEBUFFER_BINDING);
1203
Jamie Madillef9fcd92018-11-28 14:03:59 -05001204 if (mDrawFramebuffer)
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001205 {
Jamie Madillef9fcd92018-11-28 14:03:59 -05001206 if (mDrawFramebuffer->hasAnyDirtyBit())
1207 {
1208 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
1209 }
1210
1211 if (mRobustResourceInit && mDrawFramebuffer->hasResourceThatNeedsInit())
1212 {
1213 mDirtyObjects.set(DIRTY_OBJECT_DRAW_ATTACHMENTS);
1214 }
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001215 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001216}
1217
1218Framebuffer *State::getTargetFramebuffer(GLenum target) const
1219{
1220 switch (target)
1221 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001222 case GL_READ_FRAMEBUFFER_ANGLE:
1223 return mReadFramebuffer;
1224 case GL_DRAW_FRAMEBUFFER_ANGLE:
1225 case GL_FRAMEBUFFER:
1226 return mDrawFramebuffer;
1227 default:
1228 UNREACHABLE();
Yunchao Hef81ce4a2017-04-24 10:49:17 +08001229 return nullptr;
Shannon Woods53a94a82014-06-24 15:20:36 -04001230 }
1231}
1232
Shannon Woods53a94a82014-06-24 15:20:36 -04001233bool State::removeReadFramebufferBinding(GLuint framebuffer)
1234{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001235 if (mReadFramebuffer != nullptr && mReadFramebuffer->id() == framebuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001236 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001237 setReadFramebufferBinding(nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001238 return true;
1239 }
1240
1241 return false;
1242}
1243
1244bool State::removeDrawFramebufferBinding(GLuint framebuffer)
1245{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001246 if (mReadFramebuffer != nullptr && mDrawFramebuffer->id() == framebuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001247 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001248 setDrawFramebufferBinding(nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001249 return true;
1250 }
1251
1252 return false;
1253}
1254
Jamie Madill7267aa62018-04-17 15:28:21 -04001255void State::setVertexArrayBinding(const Context *context, VertexArray *vertexArray)
Shannon Woods53a94a82014-06-24 15:20:36 -04001256{
James Darpiniane8a93c62018-01-04 18:02:24 -08001257 if (mVertexArray == vertexArray)
1258 return;
1259 if (mVertexArray)
Jamie Madillbf5177d2018-08-21 12:58:20 -04001260 mVertexArray->onBindingChanged(context, -1);
Shannon Woods53a94a82014-06-24 15:20:36 -04001261 mVertexArray = vertexArray;
James Darpiniane8a93c62018-01-04 18:02:24 -08001262 if (vertexArray)
Jamie Madillbf5177d2018-08-21 12:58:20 -04001263 vertexArray->onBindingChanged(context, 1);
Jamie Madill0b9e9032015-08-17 11:51:52 +00001264 mDirtyBits.set(DIRTY_BIT_VERTEX_ARRAY_BINDING);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001265
1266 if (mVertexArray && mVertexArray->hasAnyDirtyBit())
1267 {
1268 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1269 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001270}
1271
Jamie Madill7267aa62018-04-17 15:28:21 -04001272bool State::removeVertexArrayBinding(const Context *context, GLuint vertexArray)
Shannon Woods53a94a82014-06-24 15:20:36 -04001273{
James Darpiniane8a93c62018-01-04 18:02:24 -08001274 if (mVertexArray && mVertexArray->id() == vertexArray)
Shannon Woods53a94a82014-06-24 15:20:36 -04001275 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001276 mVertexArray->onBindingChanged(context, -1);
Yunchao Hed7297bf2017-04-19 15:27:10 +08001277 mVertexArray = nullptr;
Jamie Madill0b9e9032015-08-17 11:51:52 +00001278 mDirtyBits.set(DIRTY_BIT_VERTEX_ARRAY_BINDING);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001279 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001280 return true;
1281 }
1282
1283 return false;
1284}
1285
Markus Tavenrath774fe562018-11-18 14:14:49 +01001286GLuint State::getVertexArrayId() const
1287{
1288 ASSERT(mVertexArray != nullptr);
1289 return mVertexArray->id();
1290}
1291
Jamie Madill4928b7c2017-06-20 12:57:39 -04001292void State::bindVertexBuffer(const Context *context,
1293 GLuint bindingIndex,
Shao80957d92017-02-20 21:25:59 +08001294 Buffer *boundBuffer,
1295 GLintptr offset,
1296 GLsizei stride)
1297{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001298 getVertexArray()->bindVertexBuffer(context, bindingIndex, boundBuffer, offset, stride);
Shao80957d92017-02-20 21:25:59 +08001299 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1300}
1301
Shaodde78e82017-05-22 14:13:27 +08001302void State::setVertexAttribBinding(const Context *context, GLuint attribIndex, GLuint bindingIndex)
Shao80957d92017-02-20 21:25:59 +08001303{
Shaodde78e82017-05-22 14:13:27 +08001304 getVertexArray()->setVertexAttribBinding(context, attribIndex, bindingIndex);
Shao80957d92017-02-20 21:25:59 +08001305 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1306}
1307
1308void State::setVertexAttribFormat(GLuint attribIndex,
1309 GLint size,
1310 GLenum type,
1311 bool normalized,
1312 bool pureInteger,
1313 GLuint relativeOffset)
1314{
1315 getVertexArray()->setVertexAttribFormat(attribIndex, size, type, normalized, pureInteger,
1316 relativeOffset);
1317 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1318}
1319
1320void State::setVertexBindingDivisor(GLuint bindingIndex, GLuint divisor)
1321{
1322 getVertexArray()->setVertexBindingDivisor(bindingIndex, divisor);
1323 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1324}
1325
Jamie Madill6f755b22018-10-09 12:48:54 -04001326angle::Result State::setProgram(const Context *context, Program *newProgram)
Shannon Woods53a94a82014-06-24 15:20:36 -04001327{
Geoff Lang7dd2e102014-11-10 15:19:26 -05001328 if (mProgram != newProgram)
Shannon Woods53a94a82014-06-24 15:20:36 -04001329 {
Geoff Lang7dd2e102014-11-10 15:19:26 -05001330 if (mProgram)
1331 {
Jamie Madille3bb6b72018-10-03 17:51:15 -04001332 unsetActiveTextures(mProgram->getActiveSamplersMask());
Jamie Madill6c1f6712017-02-14 19:08:04 -05001333 mProgram->release(context);
Geoff Lang7dd2e102014-11-10 15:19:26 -05001334 }
1335
1336 mProgram = newProgram;
1337
1338 if (mProgram)
1339 {
1340 newProgram->addRef();
Jamie Madille3bb6b72018-10-03 17:51:15 -04001341 ANGLE_TRY(onProgramExecutableChange(context, newProgram));
Geoff Lang7dd2e102014-11-10 15:19:26 -05001342 }
Jamie Madilldf836ff2018-10-01 10:36:24 -04001343
1344 // Note that rendering is undefined if glUseProgram(0) is called. But ANGLE will generate
1345 // an error if the app tries to draw in this case.
1346
Jamie Madilla779b612017-07-24 11:46:05 -04001347 mDirtyBits.set(DIRTY_BIT_PROGRAM_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001348 }
Jamie Madille3bb6b72018-10-03 17:51:15 -04001349
Jamie Madill6f755b22018-10-09 12:48:54 -04001350 return angle::Result::Continue();
Shannon Woods53a94a82014-06-24 15:20:36 -04001351}
1352
Jamie Madill4928b7c2017-06-20 12:57:39 -04001353void State::setTransformFeedbackBinding(const Context *context,
1354 TransformFeedback *transformFeedback)
Shannon Woods53a94a82014-06-24 15:20:36 -04001355{
James Darpiniane8a93c62018-01-04 18:02:24 -08001356 if (transformFeedback == mTransformFeedback.get())
1357 return;
1358 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -04001359 mTransformFeedback->onBindingChanged(context, false);
Jamie Madill4928b7c2017-06-20 12:57:39 -04001360 mTransformFeedback.set(context, transformFeedback);
James Darpiniane8a93c62018-01-04 18:02:24 -08001361 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -04001362 mTransformFeedback->onBindingChanged(context, true);
Geoff Langded79232017-11-28 15:21:11 -05001363 mDirtyBits.set(DIRTY_BIT_TRANSFORM_FEEDBACK_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001364}
1365
Jamie Madill4928b7c2017-06-20 12:57:39 -04001366bool State::removeTransformFeedbackBinding(const Context *context, GLuint transformFeedback)
Shannon Woods53a94a82014-06-24 15:20:36 -04001367{
1368 if (mTransformFeedback.id() == transformFeedback)
1369 {
James Darpiniane8a93c62018-01-04 18:02:24 -08001370 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -04001371 mTransformFeedback->onBindingChanged(context, false);
Jamie Madill4928b7c2017-06-20 12:57:39 -04001372 mTransformFeedback.set(context, nullptr);
Corentin Walleza2257da2016-04-19 16:43:12 -04001373 return true;
Shannon Woods53a94a82014-06-24 15:20:36 -04001374 }
Corentin Walleza2257da2016-04-19 16:43:12 -04001375
1376 return false;
Shannon Woods53a94a82014-06-24 15:20:36 -04001377}
1378
Yunchao Hea336b902017-08-02 16:05:21 +08001379void State::setProgramPipelineBinding(const Context *context, ProgramPipeline *pipeline)
1380{
1381 mProgramPipeline.set(context, pipeline);
1382}
1383
1384void State::detachProgramPipeline(const Context *context, GLuint pipeline)
1385{
1386 mProgramPipeline.set(context, nullptr);
1387}
1388
Corentin Wallezad3ae902018-03-09 13:40:42 -05001389bool State::isQueryActive(QueryType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001390{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001391 const Query *query = mActiveQueries[type].get();
1392 if (query != nullptr)
Shannon Woods53a94a82014-06-24 15:20:36 -04001393 {
Corentin Wallezad3ae902018-03-09 13:40:42 -05001394 return true;
1395 }
1396
1397 QueryType alternativeType;
1398 if (GetAlternativeQueryType(type, &alternativeType))
1399 {
1400 query = mActiveQueries[alternativeType].get();
1401 return query != nullptr;
Ian Ewell3ffd78b2016-01-22 16:09:42 -05001402 }
1403
1404 return false;
1405}
1406
1407bool State::isQueryActive(Query *query) const
1408{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001409 for (auto &queryPointer : mActiveQueries)
Ian Ewell3ffd78b2016-01-22 16:09:42 -05001410 {
Corentin Wallezad3ae902018-03-09 13:40:42 -05001411 if (queryPointer.get() == query)
Shannon Woods53a94a82014-06-24 15:20:36 -04001412 {
1413 return true;
1414 }
1415 }
1416
1417 return false;
1418}
1419
Corentin Wallezad3ae902018-03-09 13:40:42 -05001420void State::setActiveQuery(const Context *context, QueryType type, Query *query)
Shannon Woods53a94a82014-06-24 15:20:36 -04001421{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001422 mActiveQueries[type].set(context, query);
Shannon Woods53a94a82014-06-24 15:20:36 -04001423}
1424
Corentin Wallezad3ae902018-03-09 13:40:42 -05001425GLuint State::getActiveQueryId(QueryType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001426{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001427 const Query *query = getActiveQuery(type);
Shannon Woods53a94a82014-06-24 15:20:36 -04001428 return (query ? query->id() : 0u);
1429}
1430
Corentin Wallezad3ae902018-03-09 13:40:42 -05001431Query *State::getActiveQuery(QueryType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001432{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001433 return mActiveQueries[type].get();
Shannon Woods53a94a82014-06-24 15:20:36 -04001434}
1435
Corentin Wallez336129f2017-10-17 15:55:40 -04001436void State::setIndexedBufferBinding(const Context *context,
1437 BufferBinding target,
1438 GLuint index,
1439 Buffer *buffer,
1440 GLintptr offset,
1441 GLsizeiptr size)
Jiajia Qin9d7d0b12016-11-29 16:30:31 +08001442{
Corentin Wallez336129f2017-10-17 15:55:40 -04001443 setBufferBinding(context, target, buffer);
Jiajia Qin9d7d0b12016-11-29 16:30:31 +08001444
Corentin Wallez336129f2017-10-17 15:55:40 -04001445 switch (target)
1446 {
1447 case BufferBinding::TransformFeedback:
1448 mTransformFeedback->bindIndexedBuffer(context, index, buffer, offset, size);
James Darpiniane8a93c62018-01-04 18:02:24 -08001449 setBufferBinding(context, target, buffer);
Corentin Wallez336129f2017-10-17 15:55:40 -04001450 break;
1451 case BufferBinding::Uniform:
Jamie Madillbf5177d2018-08-21 12:58:20 -04001452 UpdateIndexedBufferBinding(context, &mUniformBuffers[index], buffer, target, offset,
1453 size);
Corentin Wallez336129f2017-10-17 15:55:40 -04001454 break;
1455 case BufferBinding::AtomicCounter:
Jamie Madillbf5177d2018-08-21 12:58:20 -04001456 UpdateIndexedBufferBinding(context, &mAtomicCounterBuffers[index], buffer, target,
1457 offset, size);
Corentin Wallez336129f2017-10-17 15:55:40 -04001458 break;
1459 case BufferBinding::ShaderStorage:
Jamie Madillbf5177d2018-08-21 12:58:20 -04001460 UpdateIndexedBufferBinding(context, &mShaderStorageBuffers[index], buffer, target,
1461 offset, size);
Corentin Wallez336129f2017-10-17 15:55:40 -04001462 break;
1463 default:
1464 UNREACHABLE();
1465 break;
1466 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001467}
1468
Geoff Lang5d124a62015-09-15 13:03:27 -04001469const OffsetBindingPointer<Buffer> &State::getIndexedUniformBuffer(size_t index) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001470{
Shannon Woodsf3acaf92014-09-23 18:07:11 -04001471 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
Geoff Lang5d124a62015-09-15 13:03:27 -04001472 return mUniformBuffers[index];
Gregoire Payen de La Garanderie68694e92015-03-24 14:03:37 +00001473}
1474
Jiajia Qin6eafb042016-12-27 17:04:07 +08001475const OffsetBindingPointer<Buffer> &State::getIndexedAtomicCounterBuffer(size_t index) const
1476{
1477 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
1478 return mAtomicCounterBuffers[index];
1479}
1480
Jiajia Qinf546e7d2017-03-27 14:12:59 +08001481const OffsetBindingPointer<Buffer> &State::getIndexedShaderStorageBuffer(size_t index) const
1482{
1483 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
1484 return mShaderStorageBuffers[index];
1485}
1486
Corentin Wallez336129f2017-10-17 15:55:40 -04001487Buffer *State::getTargetBuffer(BufferBinding target) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001488{
1489 switch (target)
1490 {
Corentin Wallez336129f2017-10-17 15:55:40 -04001491 case BufferBinding::ElementArray:
Jamie Madillcd0a0a32018-10-18 18:41:57 -04001492 return getVertexArray()->getElementArrayBuffer();
Corentin Wallez336129f2017-10-17 15:55:40 -04001493 default:
1494 return mBoundBuffers[target].get();
Shannon Woods53a94a82014-06-24 15:20:36 -04001495 }
1496}
1497
James Darpinian4d9d4832018-03-13 12:43:28 -07001498void State::detachBuffer(const Context *context, const Buffer *buffer)
Yuly Novikov5807a532015-12-03 13:01:22 -05001499{
James Darpinian4d9d4832018-03-13 12:43:28 -07001500 if (!buffer->isBound())
1501 {
1502 return;
1503 }
1504 GLuint bufferName = buffer->id();
James Darpiniane8a93c62018-01-04 18:02:24 -08001505 for (auto target : angle::AllEnums<BufferBinding>())
Yuly Novikov5807a532015-12-03 13:01:22 -05001506 {
James Darpiniane8a93c62018-01-04 18:02:24 -08001507 if (mBoundBuffers[target].id() == bufferName)
Yuly Novikov5807a532015-12-03 13:01:22 -05001508 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001509 UpdateBufferBinding(context, &mBoundBuffers[target], nullptr, target);
Yuly Novikov5807a532015-12-03 13:01:22 -05001510 }
1511 }
1512
1513 TransformFeedback *curTransformFeedback = getCurrentTransformFeedback();
1514 if (curTransformFeedback)
1515 {
Jamie Madill4928b7c2017-06-20 12:57:39 -04001516 curTransformFeedback->detachBuffer(context, bufferName);
Yuly Novikov5807a532015-12-03 13:01:22 -05001517 }
1518
Jamie Madill4928b7c2017-06-20 12:57:39 -04001519 getVertexArray()->detachBuffer(context, bufferName);
James Darpiniane8a93c62018-01-04 18:02:24 -08001520
1521 for (auto &buf : mUniformBuffers)
1522 {
1523 if (buf.id() == bufferName)
1524 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001525 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::Uniform, 0, 0);
James Darpiniane8a93c62018-01-04 18:02:24 -08001526 }
1527 }
1528
1529 for (auto &buf : mAtomicCounterBuffers)
1530 {
1531 if (buf.id() == bufferName)
1532 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001533 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::AtomicCounter, 0, 0);
James Darpiniane8a93c62018-01-04 18:02:24 -08001534 }
1535 }
1536
1537 for (auto &buf : mShaderStorageBuffers)
1538 {
1539 if (buf.id() == bufferName)
1540 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001541 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::ShaderStorage, 0, 0);
James Darpiniane8a93c62018-01-04 18:02:24 -08001542 }
1543 }
Yuly Novikov5807a532015-12-03 13:01:22 -05001544}
1545
Shannon Woods53a94a82014-06-24 15:20:36 -04001546void State::setEnableVertexAttribArray(unsigned int attribNum, bool enabled)
1547{
1548 getVertexArray()->enableAttribute(attribNum, enabled);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001549 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001550}
1551
1552void State::setVertexAttribf(GLuint index, const GLfloat values[4])
1553{
Shannon Woods23e05002014-09-22 19:07:27 -04001554 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001555 mVertexAttribCurrentValues[index].setFloatValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001556 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1557 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001558 mCurrentValuesTypeMask.setIndex(GL_FLOAT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001559}
1560
1561void State::setVertexAttribu(GLuint index, const GLuint values[4])
1562{
Shannon Woods23e05002014-09-22 19:07:27 -04001563 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001564 mVertexAttribCurrentValues[index].setUnsignedIntValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001565 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1566 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001567 mCurrentValuesTypeMask.setIndex(GL_UNSIGNED_INT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001568}
1569
1570void State::setVertexAttribi(GLuint index, const GLint values[4])
1571{
Shannon Woods23e05002014-09-22 19:07:27 -04001572 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001573 mVertexAttribCurrentValues[index].setIntValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001574 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1575 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001576 mCurrentValuesTypeMask.setIndex(GL_INT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001577}
1578
Shaodde78e82017-05-22 14:13:27 +08001579void State::setVertexAttribPointer(const Context *context,
1580 unsigned int attribNum,
1581 Buffer *boundBuffer,
1582 GLint size,
1583 GLenum type,
1584 bool normalized,
1585 bool pureInteger,
1586 GLsizei stride,
1587 const void *pointer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001588{
Shaodde78e82017-05-22 14:13:27 +08001589 getVertexArray()->setVertexAttribPointer(context, attribNum, boundBuffer, size, type,
1590 normalized, pureInteger, stride, pointer);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001591 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Jamie Madill0b9e9032015-08-17 11:51:52 +00001592}
1593
Shaodde78e82017-05-22 14:13:27 +08001594void State::setVertexAttribDivisor(const Context *context, GLuint index, GLuint divisor)
Jamie Madill0b9e9032015-08-17 11:51:52 +00001595{
Shaodde78e82017-05-22 14:13:27 +08001596 getVertexArray()->setVertexAttribDivisor(context, index, divisor);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001597 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001598}
1599
Shannon Woods53a94a82014-06-24 15:20:36 -04001600const void *State::getVertexAttribPointer(unsigned int attribNum) const
1601{
1602 return getVertexArray()->getVertexAttribute(attribNum).pointer;
1603}
1604
1605void State::setPackAlignment(GLint alignment)
1606{
1607 mPack.alignment = alignment;
Jamie Madillc67323a2017-11-02 23:11:41 -04001608 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001609}
1610
Shannon Woods53a94a82014-06-24 15:20:36 -04001611void State::setPackReverseRowOrder(bool reverseRowOrder)
1612{
1613 mPack.reverseRowOrder = reverseRowOrder;
Jamie Madillc67323a2017-11-02 23:11:41 -04001614 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001615}
1616
Minmin Gongadff67b2015-10-14 10:34:45 -04001617void State::setPackRowLength(GLint rowLength)
1618{
1619 mPack.rowLength = rowLength;
Jamie Madillc67323a2017-11-02 23:11:41 -04001620 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001621}
1622
Minmin Gongadff67b2015-10-14 10:34:45 -04001623void State::setPackSkipRows(GLint skipRows)
1624{
1625 mPack.skipRows = skipRows;
Jamie Madillc67323a2017-11-02 23:11:41 -04001626 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001627}
1628
Minmin Gongadff67b2015-10-14 10:34:45 -04001629void State::setPackSkipPixels(GLint skipPixels)
1630{
1631 mPack.skipPixels = skipPixels;
Jamie Madillc67323a2017-11-02 23:11:41 -04001632 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001633}
1634
Shannon Woods53a94a82014-06-24 15:20:36 -04001635void State::setUnpackAlignment(GLint alignment)
1636{
1637 mUnpack.alignment = alignment;
Jamie Madillc67323a2017-11-02 23:11:41 -04001638 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001639}
1640
Minmin Gongb8aee3b2015-01-27 14:42:36 -08001641void State::setUnpackRowLength(GLint rowLength)
1642{
1643 mUnpack.rowLength = rowLength;
Jamie Madillc67323a2017-11-02 23:11:41 -04001644 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongb8aee3b2015-01-27 14:42:36 -08001645}
1646
Minmin Gongadff67b2015-10-14 10:34:45 -04001647void State::setUnpackImageHeight(GLint imageHeight)
1648{
1649 mUnpack.imageHeight = imageHeight;
Jamie Madillc67323a2017-11-02 23:11:41 -04001650 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001651}
1652
Minmin Gongadff67b2015-10-14 10:34:45 -04001653void State::setUnpackSkipImages(GLint skipImages)
1654{
1655 mUnpack.skipImages = skipImages;
Jamie Madillc67323a2017-11-02 23:11:41 -04001656 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001657}
1658
Minmin Gongadff67b2015-10-14 10:34:45 -04001659void State::setUnpackSkipRows(GLint skipRows)
1660{
1661 mUnpack.skipRows = skipRows;
Jamie Madillc67323a2017-11-02 23:11:41 -04001662 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001663}
1664
Minmin Gongadff67b2015-10-14 10:34:45 -04001665void State::setUnpackSkipPixels(GLint skipPixels)
1666{
1667 mUnpack.skipPixels = skipPixels;
Jamie Madillc67323a2017-11-02 23:11:41 -04001668 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001669}
1670
Sami Väisänena797e062016-05-12 15:23:40 +03001671void State::setCoverageModulation(GLenum components)
1672{
1673 mCoverageModulation = components;
1674 mDirtyBits.set(DIRTY_BIT_COVERAGE_MODULATION);
1675}
1676
Sami Väisänene45e53b2016-05-25 10:36:04 +03001677void State::loadPathRenderingMatrix(GLenum matrixMode, const GLfloat *matrix)
1678{
1679 if (matrixMode == GL_PATH_MODELVIEW_CHROMIUM)
1680 {
1681 memcpy(mPathMatrixMV, matrix, 16 * sizeof(GLfloat));
jchen10bb2f2c42018-09-16 09:47:38 +08001682 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING);
Sami Väisänene45e53b2016-05-25 10:36:04 +03001683 }
1684 else if (matrixMode == GL_PATH_PROJECTION_CHROMIUM)
1685 {
1686 memcpy(mPathMatrixProj, matrix, 16 * sizeof(GLfloat));
jchen10bb2f2c42018-09-16 09:47:38 +08001687 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING);
Sami Väisänene45e53b2016-05-25 10:36:04 +03001688 }
1689 else
1690 {
1691 UNREACHABLE();
1692 }
1693}
1694
1695const GLfloat *State::getPathRenderingMatrix(GLenum which) const
1696{
1697 if (which == GL_PATH_MODELVIEW_MATRIX_CHROMIUM)
1698 {
1699 return mPathMatrixMV;
1700 }
1701 else if (which == GL_PATH_PROJECTION_MATRIX_CHROMIUM)
1702 {
1703 return mPathMatrixProj;
1704 }
1705
1706 UNREACHABLE();
1707 return nullptr;
1708}
1709
1710void State::setPathStencilFunc(GLenum func, GLint ref, GLuint mask)
1711{
1712 mPathStencilFunc = func;
1713 mPathStencilRef = ref;
1714 mPathStencilMask = mask;
jchen10bb2f2c42018-09-16 09:47:38 +08001715 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING);
Sami Väisänene45e53b2016-05-25 10:36:04 +03001716}
1717
Geoff Lang1d2c41d2016-10-19 16:14:46 -07001718void State::setFramebufferSRGB(bool sRGB)
1719{
1720 mFramebufferSRGB = sRGB;
1721 mDirtyBits.set(DIRTY_BIT_FRAMEBUFFER_SRGB);
1722}
1723
jchen1082af6202018-06-22 10:59:52 +08001724void State::setMaxShaderCompilerThreads(GLuint count)
1725{
1726 mMaxShaderCompilerThreads = count;
1727}
1728
Shannon Woods53a94a82014-06-24 15:20:36 -04001729void State::getBooleanv(GLenum pname, GLboolean *params)
1730{
1731 switch (pname)
1732 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001733 case GL_SAMPLE_COVERAGE_INVERT:
1734 *params = mSampleCoverageInvert;
1735 break;
1736 case GL_DEPTH_WRITEMASK:
1737 *params = mDepthStencil.depthMask;
1738 break;
1739 case GL_COLOR_WRITEMASK:
1740 params[0] = mBlend.colorMaskRed;
1741 params[1] = mBlend.colorMaskGreen;
1742 params[2] = mBlend.colorMaskBlue;
1743 params[3] = mBlend.colorMaskAlpha;
1744 break;
1745 case GL_CULL_FACE:
1746 *params = mRasterizer.cullFace;
1747 break;
1748 case GL_POLYGON_OFFSET_FILL:
1749 *params = mRasterizer.polygonOffsetFill;
1750 break;
1751 case GL_SAMPLE_ALPHA_TO_COVERAGE:
1752 *params = mBlend.sampleAlphaToCoverage;
1753 break;
1754 case GL_SAMPLE_COVERAGE:
1755 *params = mSampleCoverage;
1756 break;
1757 case GL_SAMPLE_MASK:
1758 *params = mSampleMask;
1759 break;
1760 case GL_SCISSOR_TEST:
1761 *params = mScissorTest;
1762 break;
1763 case GL_STENCIL_TEST:
1764 *params = mDepthStencil.stencilTest;
1765 break;
1766 case GL_DEPTH_TEST:
1767 *params = mDepthStencil.depthTest;
1768 break;
1769 case GL_BLEND:
1770 *params = mBlend.blend;
1771 break;
1772 case GL_DITHER:
1773 *params = mBlend.dither;
1774 break;
1775 case GL_TRANSFORM_FEEDBACK_ACTIVE:
1776 *params = getCurrentTransformFeedback()->isActive() ? GL_TRUE : GL_FALSE;
1777 break;
1778 case GL_TRANSFORM_FEEDBACK_PAUSED:
1779 *params = getCurrentTransformFeedback()->isPaused() ? GL_TRUE : GL_FALSE;
1780 break;
1781 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
1782 *params = mPrimitiveRestart;
1783 break;
1784 case GL_RASTERIZER_DISCARD:
1785 *params = isRasterizerDiscardEnabled() ? GL_TRUE : GL_FALSE;
1786 break;
1787 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
1788 *params = mDebug.isOutputSynchronous() ? GL_TRUE : GL_FALSE;
1789 break;
1790 case GL_DEBUG_OUTPUT:
1791 *params = mDebug.isOutputEnabled() ? GL_TRUE : GL_FALSE;
1792 break;
1793 case GL_MULTISAMPLE_EXT:
1794 *params = mMultiSampling;
1795 break;
1796 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
1797 *params = mSampleAlphaToOne;
1798 break;
1799 case GL_BIND_GENERATES_RESOURCE_CHROMIUM:
1800 *params = isBindGeneratesResourceEnabled() ? GL_TRUE : GL_FALSE;
1801 break;
1802 case GL_CLIENT_ARRAYS_ANGLE:
1803 *params = areClientArraysEnabled() ? GL_TRUE : GL_FALSE;
1804 break;
1805 case GL_FRAMEBUFFER_SRGB_EXT:
1806 *params = getFramebufferSRGB() ? GL_TRUE : GL_FALSE;
1807 break;
1808 case GL_ROBUST_RESOURCE_INITIALIZATION_ANGLE:
1809 *params = mRobustResourceInit ? GL_TRUE : GL_FALSE;
1810 break;
1811 case GL_PROGRAM_CACHE_ENABLED_ANGLE:
1812 *params = mProgramBinaryCacheEnabled ? GL_TRUE : GL_FALSE;
1813 break;
Lingfeng Yangd0febe72018-05-17 22:36:52 -07001814 case GL_LIGHT_MODEL_TWO_SIDE:
1815 *params = IsLightModelTwoSided(&mGLES1State);
1816 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001817 default:
1818 UNREACHABLE();
1819 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04001820 }
1821}
1822
1823void State::getFloatv(GLenum pname, GLfloat *params)
1824{
1825 // Please note: DEPTH_CLEAR_VALUE is included in our internal getFloatv implementation
1826 // because it is stored as a float, despite the fact that the GL ES 2.0 spec names
1827 // GetIntegerv as its native query function. As it would require conversion in any
1828 // case, this should make no difference to the calling application.
1829 switch (pname)
1830 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001831 case GL_LINE_WIDTH:
1832 *params = mLineWidth;
1833 break;
1834 case GL_SAMPLE_COVERAGE_VALUE:
1835 *params = mSampleCoverageValue;
1836 break;
1837 case GL_DEPTH_CLEAR_VALUE:
1838 *params = mDepthClearValue;
1839 break;
1840 case GL_POLYGON_OFFSET_FACTOR:
1841 *params = mRasterizer.polygonOffsetFactor;
1842 break;
1843 case GL_POLYGON_OFFSET_UNITS:
1844 *params = mRasterizer.polygonOffsetUnits;
1845 break;
1846 case GL_DEPTH_RANGE:
1847 params[0] = mNearZ;
1848 params[1] = mFarZ;
1849 break;
1850 case GL_COLOR_CLEAR_VALUE:
1851 params[0] = mColorClearValue.red;
1852 params[1] = mColorClearValue.green;
1853 params[2] = mColorClearValue.blue;
1854 params[3] = mColorClearValue.alpha;
1855 break;
1856 case GL_BLEND_COLOR:
1857 params[0] = mBlendColor.red;
1858 params[1] = mBlendColor.green;
1859 params[2] = mBlendColor.blue;
1860 params[3] = mBlendColor.alpha;
1861 break;
1862 case GL_MULTISAMPLE_EXT:
1863 *params = static_cast<GLfloat>(mMultiSampling);
1864 break;
1865 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
1866 *params = static_cast<GLfloat>(mSampleAlphaToOne);
1867 break;
1868 case GL_COVERAGE_MODULATION_CHROMIUM:
1869 params[0] = static_cast<GLfloat>(mCoverageModulation);
1870 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -07001871 case GL_ALPHA_TEST_REF:
1872 *params = mGLES1State.mAlphaTestRef;
1873 break;
Lingfeng Yanga43994c2018-03-29 07:21:41 -07001874 case GL_CURRENT_COLOR:
1875 {
1876 const auto &color = mGLES1State.mCurrentColor;
1877 params[0] = color.red;
1878 params[1] = color.green;
1879 params[2] = color.blue;
1880 params[3] = color.alpha;
1881 break;
1882 }
Lingfeng Yang5a7e61b2018-03-29 16:50:32 -07001883 case GL_CURRENT_NORMAL:
1884 {
1885 const auto &normal = mGLES1State.mCurrentNormal;
1886 params[0] = normal[0];
1887 params[1] = normal[1];
1888 params[2] = normal[2];
1889 break;
1890 }
Lingfeng Yang038dd532018-03-29 17:31:52 -07001891 case GL_CURRENT_TEXTURE_COORDS:
1892 {
1893 const auto &texcoord = mGLES1State.mCurrentTextureCoords[mActiveSampler];
1894 params[0] = texcoord.s;
1895 params[1] = texcoord.t;
1896 params[2] = texcoord.r;
1897 params[3] = texcoord.q;
1898 break;
1899 }
Lingfeng Yang3a41af62018-04-09 07:28:56 -07001900 case GL_MODELVIEW_MATRIX:
1901 memcpy(params, mGLES1State.mModelviewMatrices.back().data(), 16 * sizeof(GLfloat));
1902 break;
1903 case GL_PROJECTION_MATRIX:
1904 memcpy(params, mGLES1State.mProjectionMatrices.back().data(), 16 * sizeof(GLfloat));
1905 break;
1906 case GL_TEXTURE_MATRIX:
1907 memcpy(params, mGLES1State.mTextureMatrices[mActiveSampler].back().data(),
1908 16 * sizeof(GLfloat));
1909 break;
Lingfeng Yangd0febe72018-05-17 22:36:52 -07001910 case GL_LIGHT_MODEL_AMBIENT:
1911 GetLightModelParameters(&mGLES1State, pname, params);
1912 break;
Lingfeng Yang7ba3f422018-06-01 09:43:04 -07001913 case GL_FOG_MODE:
1914 case GL_FOG_DENSITY:
1915 case GL_FOG_START:
1916 case GL_FOG_END:
1917 case GL_FOG_COLOR:
1918 GetFogParameters(&mGLES1State, pname, params);
1919 break;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -07001920 case GL_POINT_SIZE:
1921 GetPointSize(&mGLES1State, params);
1922 break;
1923 case GL_POINT_SIZE_MIN:
1924 case GL_POINT_SIZE_MAX:
1925 case GL_POINT_FADE_THRESHOLD_SIZE:
1926 case GL_POINT_DISTANCE_ATTENUATION:
1927 GetPointParameter(&mGLES1State, FromGLenum<PointParameter>(pname), params);
1928 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001929 default:
1930 UNREACHABLE();
1931 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04001932 }
1933}
1934
Jamie Madill526392d2018-11-16 09:35:14 -05001935angle::Result State::getIntegerv(const Context *context, GLenum pname, GLint *params)
Shannon Woods53a94a82014-06-24 15:20:36 -04001936{
1937 if (pname >= GL_DRAW_BUFFER0_EXT && pname <= GL_DRAW_BUFFER15_EXT)
1938 {
Geoff Lang3e922062018-11-15 11:26:29 -05001939 size_t drawBuffer = (pname - GL_DRAW_BUFFER0_EXT);
1940 ASSERT(drawBuffer < mMaxDrawBuffers);
Shannon Woods53a94a82014-06-24 15:20:36 -04001941 Framebuffer *framebuffer = mDrawFramebuffer;
Geoff Lang3e922062018-11-15 11:26:29 -05001942 // The default framebuffer may have fewer draw buffer states than a user-created one. The
1943 // user is always allowed to query up to GL_MAX_DRAWBUFFERS so just return GL_NONE here if
1944 // the draw buffer is out of range for this framebuffer.
1945 *params = drawBuffer < framebuffer->getDrawbufferStateCount()
1946 ? framebuffer->getDrawBufferState(drawBuffer)
1947 : GL_NONE;
Jamie Madill526392d2018-11-16 09:35:14 -05001948 return angle::Result::Continue();
Shannon Woods53a94a82014-06-24 15:20:36 -04001949 }
1950
1951 // Please note: DEPTH_CLEAR_VALUE is not included in our internal getIntegerv implementation
1952 // because it is stored as a float, despite the fact that the GL ES 2.0 spec names
1953 // GetIntegerv as its native query function. As it would require conversion in any
1954 // case, this should make no difference to the calling application. You may find it in
1955 // State::getFloatv.
1956 switch (pname)
1957 {
Corentin Wallez336129f2017-10-17 15:55:40 -04001958 case GL_ARRAY_BUFFER_BINDING:
1959 *params = mBoundBuffers[BufferBinding::Array].id();
1960 break;
1961 case GL_DRAW_INDIRECT_BUFFER_BINDING:
1962 *params = mBoundBuffers[BufferBinding::DrawIndirect].id();
1963 break;
1964 case GL_ELEMENT_ARRAY_BUFFER_BINDING:
Jamie Madillcd0a0a32018-10-18 18:41:57 -04001965 {
1966 Buffer *elementArrayBuffer = getVertexArray()->getElementArrayBuffer();
1967 *params = elementArrayBuffer ? elementArrayBuffer->id() : 0;
Corentin Wallez336129f2017-10-17 15:55:40 -04001968 break;
Jamie Madillcd0a0a32018-10-18 18:41:57 -04001969 }
Jamie Madill690c8eb2018-03-12 15:20:03 -04001970 case GL_DRAW_FRAMEBUFFER_BINDING:
1971 static_assert(GL_DRAW_FRAMEBUFFER_BINDING == GL_DRAW_FRAMEBUFFER_BINDING_ANGLE,
1972 "Enum mismatch");
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001973 *params = mDrawFramebuffer->id();
1974 break;
Jamie Madill690c8eb2018-03-12 15:20:03 -04001975 case GL_READ_FRAMEBUFFER_BINDING:
1976 static_assert(GL_READ_FRAMEBUFFER_BINDING == GL_READ_FRAMEBUFFER_BINDING_ANGLE,
1977 "Enum mismatch");
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001978 *params = mReadFramebuffer->id();
1979 break;
1980 case GL_RENDERBUFFER_BINDING:
1981 *params = mRenderbuffer.id();
1982 break;
1983 case GL_VERTEX_ARRAY_BINDING:
1984 *params = mVertexArray->id();
1985 break;
1986 case GL_CURRENT_PROGRAM:
1987 *params = mProgram ? mProgram->id() : 0;
1988 break;
1989 case GL_PACK_ALIGNMENT:
1990 *params = mPack.alignment;
1991 break;
1992 case GL_PACK_REVERSE_ROW_ORDER_ANGLE:
1993 *params = mPack.reverseRowOrder;
1994 break;
1995 case GL_PACK_ROW_LENGTH:
1996 *params = mPack.rowLength;
1997 break;
1998 case GL_PACK_SKIP_ROWS:
1999 *params = mPack.skipRows;
2000 break;
2001 case GL_PACK_SKIP_PIXELS:
2002 *params = mPack.skipPixels;
2003 break;
2004 case GL_UNPACK_ALIGNMENT:
2005 *params = mUnpack.alignment;
2006 break;
2007 case GL_UNPACK_ROW_LENGTH:
2008 *params = mUnpack.rowLength;
2009 break;
2010 case GL_UNPACK_IMAGE_HEIGHT:
2011 *params = mUnpack.imageHeight;
2012 break;
2013 case GL_UNPACK_SKIP_IMAGES:
2014 *params = mUnpack.skipImages;
2015 break;
2016 case GL_UNPACK_SKIP_ROWS:
2017 *params = mUnpack.skipRows;
2018 break;
2019 case GL_UNPACK_SKIP_PIXELS:
2020 *params = mUnpack.skipPixels;
2021 break;
2022 case GL_GENERATE_MIPMAP_HINT:
2023 *params = mGenerateMipmapHint;
2024 break;
2025 case GL_FRAGMENT_SHADER_DERIVATIVE_HINT_OES:
2026 *params = mFragmentShaderDerivativeHint;
2027 break;
2028 case GL_ACTIVE_TEXTURE:
2029 *params = (static_cast<GLint>(mActiveSampler) + GL_TEXTURE0);
2030 break;
2031 case GL_STENCIL_FUNC:
2032 *params = mDepthStencil.stencilFunc;
2033 break;
2034 case GL_STENCIL_REF:
2035 *params = mStencilRef;
2036 break;
2037 case GL_STENCIL_VALUE_MASK:
2038 *params = CastMaskValue(context, mDepthStencil.stencilMask);
2039 break;
2040 case GL_STENCIL_BACK_FUNC:
2041 *params = mDepthStencil.stencilBackFunc;
2042 break;
2043 case GL_STENCIL_BACK_REF:
2044 *params = mStencilBackRef;
2045 break;
2046 case GL_STENCIL_BACK_VALUE_MASK:
2047 *params = CastMaskValue(context, mDepthStencil.stencilBackMask);
2048 break;
2049 case GL_STENCIL_FAIL:
2050 *params = mDepthStencil.stencilFail;
2051 break;
2052 case GL_STENCIL_PASS_DEPTH_FAIL:
2053 *params = mDepthStencil.stencilPassDepthFail;
2054 break;
2055 case GL_STENCIL_PASS_DEPTH_PASS:
2056 *params = mDepthStencil.stencilPassDepthPass;
2057 break;
2058 case GL_STENCIL_BACK_FAIL:
2059 *params = mDepthStencil.stencilBackFail;
2060 break;
2061 case GL_STENCIL_BACK_PASS_DEPTH_FAIL:
2062 *params = mDepthStencil.stencilBackPassDepthFail;
2063 break;
2064 case GL_STENCIL_BACK_PASS_DEPTH_PASS:
2065 *params = mDepthStencil.stencilBackPassDepthPass;
2066 break;
2067 case GL_DEPTH_FUNC:
2068 *params = mDepthStencil.depthFunc;
2069 break;
2070 case GL_BLEND_SRC_RGB:
2071 *params = mBlend.sourceBlendRGB;
2072 break;
2073 case GL_BLEND_SRC_ALPHA:
2074 *params = mBlend.sourceBlendAlpha;
2075 break;
2076 case GL_BLEND_DST_RGB:
2077 *params = mBlend.destBlendRGB;
2078 break;
2079 case GL_BLEND_DST_ALPHA:
2080 *params = mBlend.destBlendAlpha;
2081 break;
2082 case GL_BLEND_EQUATION_RGB:
2083 *params = mBlend.blendEquationRGB;
2084 break;
2085 case GL_BLEND_EQUATION_ALPHA:
2086 *params = mBlend.blendEquationAlpha;
2087 break;
2088 case GL_STENCIL_WRITEMASK:
2089 *params = CastMaskValue(context, mDepthStencil.stencilWritemask);
2090 break;
2091 case GL_STENCIL_BACK_WRITEMASK:
2092 *params = CastMaskValue(context, mDepthStencil.stencilBackWritemask);
2093 break;
2094 case GL_STENCIL_CLEAR_VALUE:
2095 *params = mStencilClearValue;
2096 break;
2097 case GL_IMPLEMENTATION_COLOR_READ_TYPE:
Jamie Madill690c8eb2018-03-12 15:20:03 -04002098 ANGLE_TRY(mReadFramebuffer->getImplementationColorReadType(
2099 context, reinterpret_cast<GLenum *>(params)));
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002100 break;
2101 case GL_IMPLEMENTATION_COLOR_READ_FORMAT:
Jamie Madill690c8eb2018-03-12 15:20:03 -04002102 ANGLE_TRY(mReadFramebuffer->getImplementationColorReadFormat(
2103 context, reinterpret_cast<GLenum *>(params)));
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002104 break;
2105 case GL_SAMPLE_BUFFERS:
2106 case GL_SAMPLES:
Shannon Woods53a94a82014-06-24 15:20:36 -04002107 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002108 Framebuffer *framebuffer = mDrawFramebuffer;
Jamie Madill427064d2018-04-13 16:20:34 -04002109 if (framebuffer->isComplete(context))
Shannon Woods53a94a82014-06-24 15:20:36 -04002110 {
Jamie Madill427064d2018-04-13 16:20:34 -04002111 GLint samples = framebuffer->getSamples(context);
Shannon Woods53a94a82014-06-24 15:20:36 -04002112 switch (pname)
2113 {
Jamie Madilla0016b72017-07-14 14:30:46 -04002114 case GL_SAMPLE_BUFFERS:
Jamie Madille98b1b52018-03-08 09:47:23 -05002115 if (samples != 0)
Jamie Madilla0016b72017-07-14 14:30:46 -04002116 {
2117 *params = 1;
2118 }
2119 else
2120 {
2121 *params = 0;
2122 }
2123 break;
2124 case GL_SAMPLES:
Jamie Madille98b1b52018-03-08 09:47:23 -05002125 *params = samples;
Jamie Madilla0016b72017-07-14 14:30:46 -04002126 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002127 }
2128 }
2129 else
2130 {
2131 *params = 0;
2132 }
2133 }
2134 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002135 case GL_VIEWPORT:
2136 params[0] = mViewport.x;
2137 params[1] = mViewport.y;
2138 params[2] = mViewport.width;
2139 params[3] = mViewport.height;
2140 break;
2141 case GL_SCISSOR_BOX:
2142 params[0] = mScissor.x;
2143 params[1] = mScissor.y;
2144 params[2] = mScissor.width;
2145 params[3] = mScissor.height;
2146 break;
2147 case GL_CULL_FACE_MODE:
2148 *params = ToGLenum(mRasterizer.cullMode);
2149 break;
2150 case GL_FRONT_FACE:
2151 *params = mRasterizer.frontFace;
2152 break;
2153 case GL_RED_BITS:
2154 case GL_GREEN_BITS:
2155 case GL_BLUE_BITS:
2156 case GL_ALPHA_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002157 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002158 Framebuffer *framebuffer = getDrawFramebuffer();
2159 const FramebufferAttachment *colorbuffer = framebuffer->getFirstColorbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002160
2161 if (colorbuffer)
2162 {
2163 switch (pname)
2164 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002165 case GL_RED_BITS:
2166 *params = colorbuffer->getRedSize();
2167 break;
2168 case GL_GREEN_BITS:
2169 *params = colorbuffer->getGreenSize();
2170 break;
2171 case GL_BLUE_BITS:
2172 *params = colorbuffer->getBlueSize();
2173 break;
2174 case GL_ALPHA_BITS:
2175 *params = colorbuffer->getAlphaSize();
2176 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002177 }
2178 }
2179 else
2180 {
2181 *params = 0;
2182 }
2183 }
2184 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002185 case GL_DEPTH_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002186 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002187 const Framebuffer *framebuffer = getDrawFramebuffer();
2188 const FramebufferAttachment *depthbuffer = framebuffer->getDepthbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002189
2190 if (depthbuffer)
2191 {
2192 *params = depthbuffer->getDepthSize();
2193 }
2194 else
2195 {
2196 *params = 0;
2197 }
2198 }
2199 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002200 case GL_STENCIL_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002201 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002202 const Framebuffer *framebuffer = getDrawFramebuffer();
2203 const FramebufferAttachment *stencilbuffer = framebuffer->getStencilbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002204
2205 if (stencilbuffer)
2206 {
2207 *params = stencilbuffer->getStencilSize();
2208 }
2209 else
2210 {
2211 *params = 0;
2212 }
2213 }
2214 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002215 case GL_TEXTURE_BINDING_2D:
2216 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2217 *params =
2218 getSamplerTextureId(static_cast<unsigned int>(mActiveSampler), TextureType::_2D);
2219 break;
2220 case GL_TEXTURE_BINDING_RECTANGLE_ANGLE:
2221 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2222 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2223 TextureType::Rectangle);
2224 break;
2225 case GL_TEXTURE_BINDING_CUBE_MAP:
2226 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2227 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2228 TextureType::CubeMap);
2229 break;
2230 case GL_TEXTURE_BINDING_3D:
2231 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2232 *params =
2233 getSamplerTextureId(static_cast<unsigned int>(mActiveSampler), TextureType::_3D);
2234 break;
2235 case GL_TEXTURE_BINDING_2D_ARRAY:
2236 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2237 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2238 TextureType::_2DArray);
2239 break;
2240 case GL_TEXTURE_BINDING_2D_MULTISAMPLE:
2241 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2242 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2243 TextureType::_2DMultisample);
2244 break;
Olli Etuahodff32a02018-08-28 14:35:50 +03002245 case GL_TEXTURE_BINDING_2D_MULTISAMPLE_ARRAY:
2246 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2247 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2248 TextureType::_2DMultisampleArray);
2249 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002250 case GL_TEXTURE_BINDING_EXTERNAL_OES:
2251 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2252 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2253 TextureType::External);
2254 break;
2255 case GL_UNIFORM_BUFFER_BINDING:
2256 *params = mBoundBuffers[BufferBinding::Uniform].id();
2257 break;
2258 case GL_TRANSFORM_FEEDBACK_BINDING:
2259 *params = mTransformFeedback.id();
2260 break;
2261 case GL_TRANSFORM_FEEDBACK_BUFFER_BINDING:
2262 *params = mBoundBuffers[BufferBinding::TransformFeedback].id();
2263 break;
2264 case GL_COPY_READ_BUFFER_BINDING:
2265 *params = mBoundBuffers[BufferBinding::CopyRead].id();
2266 break;
2267 case GL_COPY_WRITE_BUFFER_BINDING:
2268 *params = mBoundBuffers[BufferBinding::CopyWrite].id();
2269 break;
2270 case GL_PIXEL_PACK_BUFFER_BINDING:
2271 *params = mBoundBuffers[BufferBinding::PixelPack].id();
2272 break;
2273 case GL_PIXEL_UNPACK_BUFFER_BINDING:
2274 *params = mBoundBuffers[BufferBinding::PixelUnpack].id();
2275 break;
2276 case GL_READ_BUFFER:
2277 *params = mReadFramebuffer->getReadBufferState();
2278 break;
2279 case GL_SAMPLER_BINDING:
2280 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2281 *params = getSamplerId(static_cast<GLuint>(mActiveSampler));
2282 break;
2283 case GL_DEBUG_LOGGED_MESSAGES:
2284 *params = static_cast<GLint>(mDebug.getMessageCount());
2285 break;
2286 case GL_DEBUG_NEXT_LOGGED_MESSAGE_LENGTH:
2287 *params = static_cast<GLint>(mDebug.getNextMessageLength());
2288 break;
2289 case GL_DEBUG_GROUP_STACK_DEPTH:
2290 *params = static_cast<GLint>(mDebug.getGroupStackDepth());
2291 break;
2292 case GL_MULTISAMPLE_EXT:
2293 *params = static_cast<GLint>(mMultiSampling);
2294 break;
2295 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
2296 *params = static_cast<GLint>(mSampleAlphaToOne);
2297 break;
2298 case GL_COVERAGE_MODULATION_CHROMIUM:
2299 *params = static_cast<GLint>(mCoverageModulation);
2300 break;
2301 case GL_ATOMIC_COUNTER_BUFFER_BINDING:
2302 *params = mBoundBuffers[BufferBinding::AtomicCounter].id();
2303 break;
2304 case GL_SHADER_STORAGE_BUFFER_BINDING:
2305 *params = mBoundBuffers[BufferBinding::ShaderStorage].id();
2306 break;
2307 case GL_DISPATCH_INDIRECT_BUFFER_BINDING:
2308 *params = mBoundBuffers[BufferBinding::DispatchIndirect].id();
2309 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -07002310 case GL_ALPHA_TEST_FUNC:
2311 *params = ToGLenum(mGLES1State.mAlphaTestFunc);
2312 break;
Lingfeng Yang96310cd2018-03-28 11:56:28 -07002313 case GL_CLIENT_ACTIVE_TEXTURE:
2314 *params = mGLES1State.mClientActiveTexture + GL_TEXTURE0;
2315 break;
Lingfeng Yangd2488ab2018-04-04 09:25:48 -07002316 case GL_MATRIX_MODE:
2317 *params = ToGLenum(mGLES1State.mMatrixMode);
2318 break;
Lingfeng Yanga0cfa872018-05-30 21:12:17 -07002319 case GL_SHADE_MODEL:
2320 *params = ToGLenum(mGLES1State.mShadeModel);
2321 break;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -07002322 case GL_MODELVIEW_STACK_DEPTH:
2323 case GL_PROJECTION_STACK_DEPTH:
2324 case GL_TEXTURE_STACK_DEPTH:
2325 *params = mGLES1State.getCurrentMatrixStackDepth(pname);
2326 break;
2327 case GL_LOGIC_OP_MODE:
2328 *params = ToGLenum(mGLES1State.mLogicOp);
2329 break;
2330 case GL_BLEND_SRC:
2331 *params = mBlend.sourceBlendRGB;
2332 break;
2333 case GL_BLEND_DST:
2334 *params = mBlend.destBlendRGB;
2335 break;
2336 case GL_PERSPECTIVE_CORRECTION_HINT:
2337 case GL_POINT_SMOOTH_HINT:
2338 case GL_LINE_SMOOTH_HINT:
2339 case GL_FOG_HINT:
2340 *params = mGLES1State.getHint(pname);
2341 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002342 default:
2343 UNREACHABLE();
2344 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002345 }
Jamie Madille98b1b52018-03-08 09:47:23 -05002346
Jamie Madill526392d2018-11-16 09:35:14 -05002347 return angle::Result::Continue();
Shannon Woods53a94a82014-06-24 15:20:36 -04002348}
2349
Lingfeng Yangabb09f12018-04-16 10:43:53 -07002350void State::getPointerv(const Context *context, GLenum pname, void **params) const
Geoff Lang70d0f492015-12-10 17:45:46 -05002351{
2352 switch (pname)
2353 {
2354 case GL_DEBUG_CALLBACK_FUNCTION:
2355 *params = reinterpret_cast<void *>(mDebug.getCallback());
2356 break;
2357 case GL_DEBUG_CALLBACK_USER_PARAM:
2358 *params = const_cast<void *>(mDebug.getUserParam());
2359 break;
Lingfeng Yangabb09f12018-04-16 10:43:53 -07002360 case GL_VERTEX_ARRAY_POINTER:
2361 case GL_NORMAL_ARRAY_POINTER:
2362 case GL_COLOR_ARRAY_POINTER:
2363 case GL_TEXTURE_COORD_ARRAY_POINTER:
2364 case GL_POINT_SIZE_ARRAY_POINTER_OES:
2365 QueryVertexAttribPointerv(getVertexArray()->getVertexAttribute(
2366 context->vertexArrayIndex(ParamToVertexArrayType(pname))),
2367 GL_VERTEX_ATTRIB_ARRAY_POINTER, params);
2368 return;
Geoff Lang70d0f492015-12-10 17:45:46 -05002369 default:
2370 UNREACHABLE();
2371 break;
2372 }
2373}
2374
Martin Radev66fb8202016-07-28 11:45:20 +03002375void State::getIntegeri_v(GLenum target, GLuint index, GLint *data)
Shannon Woods53a94a82014-06-24 15:20:36 -04002376{
2377 switch (target)
2378 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002379 case GL_TRANSFORM_FEEDBACK_BUFFER_BINDING:
2380 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2381 *data = mTransformFeedback->getIndexedBuffer(index).id();
2382 break;
2383 case GL_UNIFORM_BUFFER_BINDING:
2384 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2385 *data = mUniformBuffers[index].id();
2386 break;
2387 case GL_ATOMIC_COUNTER_BUFFER_BINDING:
2388 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2389 *data = mAtomicCounterBuffers[index].id();
2390 break;
2391 case GL_SHADER_STORAGE_BUFFER_BINDING:
2392 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2393 *data = mShaderStorageBuffers[index].id();
2394 break;
2395 case GL_VERTEX_BINDING_BUFFER:
2396 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2397 *data = mVertexArray->getVertexBinding(index).getBuffer().id();
2398 break;
2399 case GL_VERTEX_BINDING_DIVISOR:
2400 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2401 *data = mVertexArray->getVertexBinding(index).getDivisor();
2402 break;
2403 case GL_VERTEX_BINDING_OFFSET:
2404 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2405 *data = static_cast<GLuint>(mVertexArray->getVertexBinding(index).getOffset());
2406 break;
2407 case GL_VERTEX_BINDING_STRIDE:
2408 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2409 *data = mVertexArray->getVertexBinding(index).getStride();
2410 break;
2411 case GL_SAMPLE_MASK_VALUE:
2412 ASSERT(static_cast<size_t>(index) < mSampleMaskValues.size());
2413 *data = mSampleMaskValues[index];
2414 break;
2415 case GL_IMAGE_BINDING_NAME:
2416 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2417 *data = mImageUnits[index].texture.id();
2418 break;
2419 case GL_IMAGE_BINDING_LEVEL:
2420 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2421 *data = mImageUnits[index].level;
2422 break;
2423 case GL_IMAGE_BINDING_LAYER:
2424 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2425 *data = mImageUnits[index].layer;
2426 break;
2427 case GL_IMAGE_BINDING_ACCESS:
2428 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2429 *data = mImageUnits[index].access;
2430 break;
2431 case GL_IMAGE_BINDING_FORMAT:
2432 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2433 *data = mImageUnits[index].format;
2434 break;
2435 default:
2436 UNREACHABLE();
2437 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002438 }
Shannon Woods53a94a82014-06-24 15:20:36 -04002439}
2440
Martin Radev66fb8202016-07-28 11:45:20 +03002441void State::getInteger64i_v(GLenum target, GLuint index, GLint64 *data)
Shannon Woods53a94a82014-06-24 15:20:36 -04002442{
2443 switch (target)
2444 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002445 case GL_TRANSFORM_FEEDBACK_BUFFER_START:
2446 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2447 *data = mTransformFeedback->getIndexedBuffer(index).getOffset();
2448 break;
2449 case GL_TRANSFORM_FEEDBACK_BUFFER_SIZE:
2450 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2451 *data = mTransformFeedback->getIndexedBuffer(index).getSize();
2452 break;
2453 case GL_UNIFORM_BUFFER_START:
2454 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2455 *data = mUniformBuffers[index].getOffset();
2456 break;
2457 case GL_UNIFORM_BUFFER_SIZE:
2458 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2459 *data = mUniformBuffers[index].getSize();
2460 break;
2461 case GL_ATOMIC_COUNTER_BUFFER_START:
2462 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2463 *data = mAtomicCounterBuffers[index].getOffset();
2464 break;
2465 case GL_ATOMIC_COUNTER_BUFFER_SIZE:
2466 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2467 *data = mAtomicCounterBuffers[index].getSize();
2468 break;
2469 case GL_SHADER_STORAGE_BUFFER_START:
2470 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2471 *data = mShaderStorageBuffers[index].getOffset();
2472 break;
2473 case GL_SHADER_STORAGE_BUFFER_SIZE:
2474 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2475 *data = mShaderStorageBuffers[index].getSize();
2476 break;
2477 default:
2478 UNREACHABLE();
2479 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002480 }
Martin Radev66fb8202016-07-28 11:45:20 +03002481}
Shannon Woods53a94a82014-06-24 15:20:36 -04002482
Martin Radev66fb8202016-07-28 11:45:20 +03002483void State::getBooleani_v(GLenum target, GLuint index, GLboolean *data)
2484{
Xinghua Cao9c8e1a32017-12-06 17:59:58 +08002485 switch (target)
2486 {
2487 case GL_IMAGE_BINDING_LAYERED:
2488 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2489 *data = mImageUnits[index].layered;
2490 break;
2491 default:
2492 UNREACHABLE();
2493 break;
2494 }
Shannon Woods53a94a82014-06-24 15:20:36 -04002495}
2496
Markus Tavenrathf7f8c512018-11-18 15:56:45 +01002497angle::Result State::syncReadFramebuffer(const Context *context)
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002498{
Markus Tavenrathf7f8c512018-11-18 15:56:45 +01002499 ASSERT(mReadFramebuffer);
2500 return mReadFramebuffer->syncState(context);
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002501}
2502
Jamie Madillef9fcd92018-11-28 14:03:59 -05002503angle::Result State::syncDrawFramebuffer(const Context *context)
Markus Tavenrathf7f8c512018-11-18 15:56:45 +01002504{
2505 ASSERT(mDrawFramebuffer);
2506 return mDrawFramebuffer->syncState(context);
2507}
2508
Jamie Madillef9fcd92018-11-28 14:03:59 -05002509angle::Result State::syncDrawAttachments(const Context *context)
2510{
2511 ASSERT(mDrawFramebuffer);
2512 ASSERT(!mDrawFramebuffer->hasAnyDirtyBit());
2513 ASSERT(mRobustResourceInit);
2514 return mDrawFramebuffer->ensureDrawAttachmentsInitialized(context);
2515}
2516
Jamie Madille3e680c2018-12-03 17:49:08 -05002517angle::Result State::syncTextures(const Context *context)
Markus Tavenrathf7f8c512018-11-18 15:56:45 +01002518{
Jamie Madille3e680c2018-12-03 17:49:08 -05002519 if (mDirtyTextures.none())
2520 return angle::Result::Continue();
2521
2522 for (size_t textureIndex : mDirtyTextures)
2523 {
2524 Texture *texture = mActiveTexturesCache[textureIndex];
2525 if (texture && texture->hasAnyDirtyBit())
2526 {
2527 ANGLE_TRY(texture->syncState(context));
2528 }
2529 }
2530
2531 mDirtyTextures.reset();
2532 return angle::Result::Continue();
Markus Tavenrathf7f8c512018-11-18 15:56:45 +01002533}
2534
Jamie Madille3e680c2018-12-03 17:49:08 -05002535angle::Result State::syncImages(const Context *context)
Markus Tavenrathf7f8c512018-11-18 15:56:45 +01002536{
Jamie Madille3e680c2018-12-03 17:49:08 -05002537 if (mDirtyImages.none())
2538 return angle::Result::Continue();
2539
2540 for (size_t imageUnitIndex : mDirtyImages)
2541 {
2542 Texture *texture = mImageUnits[imageUnitIndex].texture.get();
2543 if (texture && texture->hasAnyDirtyBit())
2544 {
2545 ANGLE_TRY(texture->syncState(context));
2546 }
2547 }
2548
2549 return angle::Result::Continue();
Markus Tavenrathf7f8c512018-11-18 15:56:45 +01002550}
2551
2552angle::Result State::syncSamplers(const Context *context)
Jamie Madille25b8002018-09-20 13:39:49 -04002553{
2554 if (mDirtySamplers.none())
Markus Tavenrathf7f8c512018-11-18 15:56:45 +01002555 return angle::Result::Continue();
Jamie Madille25b8002018-09-20 13:39:49 -04002556
Jamie Madille25b8002018-09-20 13:39:49 -04002557 for (size_t samplerIndex : mDirtySamplers)
2558 {
2559 BindingPointer<Sampler> &sampler = mSamplers[samplerIndex];
2560 if (sampler.get())
2561 {
2562 sampler->syncState(context);
2563 }
2564 }
2565
2566 mDirtySamplers.reset();
Markus Tavenrathf7f8c512018-11-18 15:56:45 +01002567
2568 return angle::Result::Continue();
Jamie Madille25b8002018-09-20 13:39:49 -04002569}
2570
Jamie Madille3e680c2018-12-03 17:49:08 -05002571angle::Result State::syncVertexArray(const Context *context)
Jamie Madill81c2e252017-09-09 23:32:46 -04002572{
Jamie Madille3e680c2018-12-03 17:49:08 -05002573 ASSERT(mVertexArray);
2574 return mVertexArray->syncState(context);
2575}
Jamie Madill81c2e252017-09-09 23:32:46 -04002576
Jamie Madille3e680c2018-12-03 17:49:08 -05002577angle::Result State::syncProgram(const Context *context)
2578{
2579 return mProgram->syncState(context);
Jamie Madill81c2e252017-09-09 23:32:46 -04002580}
2581
Jamie Madill6f755b22018-10-09 12:48:54 -04002582angle::Result State::syncDirtyObject(const Context *context, GLenum target)
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002583{
2584 DirtyObjects localSet;
2585
2586 switch (target)
2587 {
2588 case GL_READ_FRAMEBUFFER:
2589 localSet.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2590 break;
2591 case GL_DRAW_FRAMEBUFFER:
2592 localSet.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2593 break;
2594 case GL_FRAMEBUFFER:
2595 localSet.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2596 localSet.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2597 break;
2598 case GL_VERTEX_ARRAY:
2599 localSet.set(DIRTY_OBJECT_VERTEX_ARRAY);
2600 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002601 case GL_TEXTURE:
Jamie Madille3e680c2018-12-03 17:49:08 -05002602 localSet.set(DIRTY_OBJECT_TEXTURES);
Jamie Madille25b8002018-09-20 13:39:49 -04002603 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002604 case GL_SAMPLER:
Jamie Madille25b8002018-09-20 13:39:49 -04002605 localSet.set(DIRTY_OBJECT_SAMPLERS);
Jamie Madill70aeda42018-08-20 12:17:40 -04002606 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002607 case GL_PROGRAM:
Jamie Madill70aeda42018-08-20 12:17:40 -04002608 localSet.set(DIRTY_OBJECT_PROGRAM);
Jamie Madill81c2e252017-09-09 23:32:46 -04002609 break;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002610 }
2611
Jamie Madillbc918e72018-03-08 09:47:21 -05002612 return syncDirtyObjects(context, localSet);
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002613}
2614
2615void State::setObjectDirty(GLenum target)
2616{
2617 switch (target)
2618 {
2619 case GL_READ_FRAMEBUFFER:
2620 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2621 break;
2622 case GL_DRAW_FRAMEBUFFER:
Jamie Madillef9fcd92018-11-28 14:03:59 -05002623 setDrawFramebufferDirty();
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002624 break;
2625 case GL_FRAMEBUFFER:
2626 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
Jamie Madillef9fcd92018-11-28 14:03:59 -05002627 setDrawFramebufferDirty();
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002628 break;
2629 case GL_VERTEX_ARRAY:
2630 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
2631 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002632 case GL_PROGRAM:
Jamie Madill70aeda42018-08-20 12:17:40 -04002633 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM);
Jamie Madille3e680c2018-12-03 17:49:08 -05002634 break;
2635 default:
Jamie Madill81c2e252017-09-09 23:32:46 -04002636 break;
Jamie Madilla779b612017-07-24 11:46:05 -04002637 }
2638}
2639
Jamie Madill6f755b22018-10-09 12:48:54 -04002640angle::Result State::onProgramExecutableChange(const Context *context, Program *program)
Jamie Madilla779b612017-07-24 11:46:05 -04002641{
2642 // OpenGL Spec:
2643 // "If LinkProgram or ProgramBinary successfully re-links a program object
2644 // that was already in use as a result of a previous call to UseProgram, then the
2645 // generated executable code will be installed as part of the current rendering state."
Jamie Madilldf836ff2018-10-01 10:36:24 -04002646 ASSERT(program->isLinked());
2647
2648 mDirtyBits.set(DIRTY_BIT_PROGRAM_EXECUTABLE);
Jamie Madill956ab4d2018-10-10 16:13:03 -04002649
2650 if (program->hasAnyDirtyBit())
2651 {
2652 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM);
2653 }
Jamie Madille3bb6b72018-10-03 17:51:15 -04002654
2655 // Set any bound textures.
2656 const ActiveTextureTypeArray &textureTypes = program->getActiveSamplerTypes();
2657 for (size_t textureIndex : program->getActiveSamplersMask())
2658 {
2659 TextureType type = textureTypes[textureIndex];
2660
2661 // This can happen if there is a conflicting texture type.
2662 if (type == TextureType::InvalidEnum)
2663 continue;
2664
2665 Texture *texture = mSamplerTextures[type][textureIndex].get();
Jamie Madille3e680c2018-12-03 17:49:08 -05002666 updateActiveTexture(context, textureIndex, texture);
Jamie Madille3bb6b72018-10-03 17:51:15 -04002667 }
2668
2669 for (size_t imageUnitIndex : program->getActiveImagesMask())
2670 {
2671 Texture *image = mImageUnits[imageUnitIndex].texture.get();
2672 if (!image)
2673 continue;
2674
2675 if (image->hasAnyDirtyBit())
2676 {
2677 ANGLE_TRY(image->syncState(context));
2678 }
2679
2680 if (image->initState() == InitState::MayNeedInit)
2681 {
2682 mCachedImageTexturesInitState = InitState::MayNeedInit;
2683 }
2684 }
2685
Jamie Madill6f755b22018-10-09 12:48:54 -04002686 return angle::Result::Continue();
Shannon Woods53a94a82014-06-24 15:20:36 -04002687}
Jamie Madillc9d442d2016-01-20 11:17:24 -05002688
Jamie Madille3e680c2018-12-03 17:49:08 -05002689void State::setTextureDirty(size_t textureUnitIndex)
2690{
2691 mDirtyObjects.set(DIRTY_OBJECT_TEXTURES);
2692 mDirtyTextures.set(textureUnitIndex);
2693}
2694
Jamie Madille25b8002018-09-20 13:39:49 -04002695void State::setSamplerDirty(size_t samplerIndex)
2696{
2697 mDirtyObjects.set(DIRTY_OBJECT_SAMPLERS);
2698 mDirtySamplers.set(samplerIndex);
2699}
2700
Xinghua Cao65ec0b22017-03-28 16:10:52 +08002701void State::setImageUnit(const Context *context,
Will Harris63aa0e52018-09-05 16:15:46 -07002702 size_t unit,
Xinghua Cao65ec0b22017-03-28 16:10:52 +08002703 Texture *texture,
2704 GLint level,
2705 GLboolean layered,
2706 GLint layer,
2707 GLenum access,
2708 GLenum format)
2709{
2710 mImageUnits[unit].texture.set(context, texture);
2711 mImageUnits[unit].level = level;
2712 mImageUnits[unit].layered = layered;
2713 mImageUnits[unit].layer = layer;
2714 mImageUnits[unit].access = access;
2715 mImageUnits[unit].format = format;
jchen1099118c12018-09-10 16:28:51 +08002716 mDirtyBits.set(DIRTY_BIT_IMAGE_BINDINGS);
Jamie Madille3e680c2018-12-03 17:49:08 -05002717
2718 onImageStateChange(context, unit);
Xinghua Cao65ec0b22017-03-28 16:10:52 +08002719}
2720
Jamie Madill81c2e252017-09-09 23:32:46 -04002721// Handle a dirty texture event.
Jamie Madille3e680c2018-12-03 17:49:08 -05002722void State::onActiveTextureChange(const Context *context, size_t textureUnit)
Jamie Madill81c2e252017-09-09 23:32:46 -04002723{
Jamie Madille3e680c2018-12-03 17:49:08 -05002724 if (mProgram)
Geoff Lange51ba632017-11-21 11:45:25 -05002725 {
Jamie Madille3e680c2018-12-03 17:49:08 -05002726 TextureType type = mProgram->getActiveSamplerTypes()[textureUnit];
2727 if (type != TextureType::InvalidEnum)
2728 {
2729 Texture *activeTexture = mSamplerTextures[type][textureUnit].get();
2730 updateActiveTexture(context, textureUnit, activeTexture);
2731 }
2732 }
2733}
2734
2735void State::onActiveTextureStateChange(const Context *context, size_t textureUnit)
2736{
2737 if (mProgram)
2738 {
2739 TextureType type = mProgram->getActiveSamplerTypes()[textureUnit];
2740 if (type != TextureType::InvalidEnum)
2741 {
2742 Texture *activeTexture = mSamplerTextures[type][textureUnit].get();
2743 const Sampler *sampler = mSamplers[textureUnit].get();
2744 updateActiveTextureState(context, textureUnit, sampler, activeTexture);
2745 }
2746 }
2747}
2748
2749void State::onImageStateChange(const Context *context, size_t unit)
2750{
2751 if (mProgram)
2752 {
2753 const ImageUnit &image = mImageUnits[unit];
2754 ASSERT(image.texture.get());
2755 if (image.texture->hasAnyDirtyBit())
2756 {
2757 mDirtyImages.set(unit);
2758 }
2759
2760 if (image.texture->initState() == InitState::MayNeedInit)
2761 {
2762 mCachedImageTexturesInitState = InitState::MayNeedInit;
2763 }
Geoff Lange51ba632017-11-21 11:45:25 -05002764 }
Jamie Madill81c2e252017-09-09 23:32:46 -04002765}
2766
Jamie Madill6d32cef2018-08-14 02:34:28 -04002767void State::onUniformBufferStateChange(size_t uniformBufferIndex)
2768{
2769 // This could be represented by a different dirty bit. Using the same one keeps it simple.
2770 mDirtyBits.set(DIRTY_BIT_UNIFORM_BUFFER_BINDINGS);
2771}
2772
Jamie Madill6f755b22018-10-09 12:48:54 -04002773angle::Result State::clearUnclearedActiveTextures(const Context *context)
Jamie Madill05b35b22017-10-03 09:01:44 -04002774{
Jamie Madilla59fc192017-11-02 12:57:58 -04002775 ASSERT(mRobustResourceInit);
Geoff Langd4fff502017-09-22 11:28:28 -04002776
Jamie Madill7e4eff12018-08-08 15:49:26 -04002777 if (!mProgram)
Jamie Madill6f755b22018-10-09 12:48:54 -04002778 return angle::Result::Continue();
Jamie Madill7e4eff12018-08-08 15:49:26 -04002779
Qin Jiajia47f6dd02018-08-10 13:36:32 +08002780 if (mCachedTexturesInitState != InitState::Initialized)
Jamie Madill05b35b22017-10-03 09:01:44 -04002781 {
Qin Jiajia47f6dd02018-08-10 13:36:32 +08002782 for (size_t textureUnitIndex : mProgram->getActiveSamplersMask())
Jamie Madill05b35b22017-10-03 09:01:44 -04002783 {
Qin Jiajia47f6dd02018-08-10 13:36:32 +08002784 Texture *texture = mActiveTexturesCache[textureUnitIndex];
2785 if (texture)
2786 {
2787 ANGLE_TRY(texture->ensureInitialized(context));
2788 }
Jamie Madill05b35b22017-10-03 09:01:44 -04002789 }
Qin Jiajia47f6dd02018-08-10 13:36:32 +08002790 mCachedTexturesInitState = InitState::Initialized;
Jamie Madill05b35b22017-10-03 09:01:44 -04002791 }
Qin Jiajia47f6dd02018-08-10 13:36:32 +08002792 if (mCachedImageTexturesInitState != InitState::Initialized)
2793 {
2794 for (size_t imageUnitIndex : mProgram->getActiveImagesMask())
2795 {
2796 Texture *texture = mImageUnits[imageUnitIndex].texture.get();
2797 if (texture)
2798 {
2799 ANGLE_TRY(texture->ensureInitialized(context));
2800 }
2801 }
2802 mCachedImageTexturesInitState = InitState::Initialized;
2803 }
Jamie Madill6f755b22018-10-09 12:48:54 -04002804 return angle::Result::Continue();
Jamie Madill05b35b22017-10-03 09:01:44 -04002805}
2806
Jamie Madillc67323a2017-11-02 23:11:41 -04002807AttributesMask State::getAndResetDirtyCurrentValues() const
2808{
2809 AttributesMask retVal = mDirtyCurrentValues;
2810 mDirtyCurrentValues.reset();
2811 return retVal;
2812}
2813
Markus Tavenrathf7f8c512018-11-18 15:56:45 +01002814constexpr State::DirtyObjectHandler State::kDirtyObjectHandlers[DIRTY_OBJECT_MAX];
2815
Jamie Madillc9d442d2016-01-20 11:17:24 -05002816} // namespace gl