blob: 20c5d4d12b9921c83ef9f684b2d0ad44fcebcf9f [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 Madill6f755b22018-10-09 12:48:54 -0400458ANGLE_INLINE angle::Result State::updateActiveTexture(const Context *context,
459 size_t textureIndex,
460 Texture *texture)
Jamie Madille3bb6b72018-10-03 17:51:15 -0400461{
462 const Sampler *sampler = mSamplers[textureIndex].get();
463
464 if (!texture)
465 {
466 mActiveTexturesCache[textureIndex] = nullptr;
467 mCompleteTextureBindings[textureIndex].bind(nullptr);
Jamie Madill6f755b22018-10-09 12:48:54 -0400468 return angle::Result::Continue();
Jamie Madille3bb6b72018-10-03 17:51:15 -0400469 }
470
Jamie Madill31116732018-10-09 18:30:01 -0400471 mCompleteTextureBindings[textureIndex].bind(texture->getImplementation());
Jamie Madille3bb6b72018-10-03 17:51:15 -0400472
473 if (!texture->isSamplerComplete(context, sampler))
474 {
475 mActiveTexturesCache[textureIndex] = nullptr;
Jamie Madill6f755b22018-10-09 12:48:54 -0400476 return angle::Result::Continue();
Jamie Madille3bb6b72018-10-03 17:51:15 -0400477 }
478
479 mActiveTexturesCache[textureIndex] = texture;
480
481 if (texture->hasAnyDirtyBit())
482 {
483 ANGLE_TRY(texture->syncState(context));
484 }
485
486 if (texture->initState() == InitState::MayNeedInit)
487 {
488 mCachedTexturesInitState = InitState::MayNeedInit;
489 }
490
Jamie Madill6f755b22018-10-09 12:48:54 -0400491 return angle::Result::Continue();
Jamie Madille3bb6b72018-10-03 17:51:15 -0400492}
493
Shannon Woods53a94a82014-06-24 15:20:36 -0400494const RasterizerState &State::getRasterizerState() const
495{
496 return mRasterizer;
497}
498
499const BlendState &State::getBlendState() const
500{
501 return mBlend;
502}
503
504const DepthStencilState &State::getDepthStencilState() const
505{
506 return mDepthStencil;
507}
508
Jamie Madillf75ab352015-03-16 10:46:52 -0400509void State::setColorClearValue(float red, float green, float blue, float alpha)
Shannon Woods53a94a82014-06-24 15:20:36 -0400510{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700511 mColorClearValue.red = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400512 mColorClearValue.green = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700513 mColorClearValue.blue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400514 mColorClearValue.alpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400515 mDirtyBits.set(DIRTY_BIT_CLEAR_COLOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400516}
517
Jamie Madillf75ab352015-03-16 10:46:52 -0400518void State::setDepthClearValue(float depth)
Shannon Woods53a94a82014-06-24 15:20:36 -0400519{
520 mDepthClearValue = depth;
Jamie Madill1b94d432015-08-07 13:23:23 -0400521 mDirtyBits.set(DIRTY_BIT_CLEAR_DEPTH);
Shannon Woods53a94a82014-06-24 15:20:36 -0400522}
523
Jamie Madillf75ab352015-03-16 10:46:52 -0400524void State::setStencilClearValue(int stencil)
Shannon Woods53a94a82014-06-24 15:20:36 -0400525{
526 mStencilClearValue = stencil;
Jamie Madill1b94d432015-08-07 13:23:23 -0400527 mDirtyBits.set(DIRTY_BIT_CLEAR_STENCIL);
Shannon Woods53a94a82014-06-24 15:20:36 -0400528}
529
Shannon Woods53a94a82014-06-24 15:20:36 -0400530void State::setColorMask(bool red, bool green, bool blue, bool alpha)
531{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700532 mBlend.colorMaskRed = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400533 mBlend.colorMaskGreen = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700534 mBlend.colorMaskBlue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400535 mBlend.colorMaskAlpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400536 mDirtyBits.set(DIRTY_BIT_COLOR_MASK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400537}
538
539void State::setDepthMask(bool mask)
540{
541 mDepthStencil.depthMask = mask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400542 mDirtyBits.set(DIRTY_BIT_DEPTH_MASK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400543}
544
Shannon Woods53a94a82014-06-24 15:20:36 -0400545void State::setRasterizerDiscard(bool enabled)
546{
547 mRasterizer.rasterizerDiscard = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400548 mDirtyBits.set(DIRTY_BIT_RASTERIZER_DISCARD_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400549}
550
Shannon Woods53a94a82014-06-24 15:20:36 -0400551void State::setCullFace(bool enabled)
552{
553 mRasterizer.cullFace = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400554 mDirtyBits.set(DIRTY_BIT_CULL_FACE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400555}
556
Corentin Wallez2e568cf2017-09-18 17:05:22 -0400557void State::setCullMode(CullFaceMode mode)
Shannon Woods53a94a82014-06-24 15:20:36 -0400558{
559 mRasterizer.cullMode = mode;
Jamie Madill1b94d432015-08-07 13:23:23 -0400560 mDirtyBits.set(DIRTY_BIT_CULL_FACE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400561}
562
563void State::setFrontFace(GLenum front)
564{
565 mRasterizer.frontFace = front;
Jamie Madill1b94d432015-08-07 13:23:23 -0400566 mDirtyBits.set(DIRTY_BIT_FRONT_FACE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400567}
568
Shannon Woods53a94a82014-06-24 15:20:36 -0400569void State::setDepthTest(bool enabled)
570{
571 mDepthStencil.depthTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400572 mDirtyBits.set(DIRTY_BIT_DEPTH_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400573}
574
575void State::setDepthFunc(GLenum depthFunc)
576{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700577 mDepthStencil.depthFunc = depthFunc;
578 mDirtyBits.set(DIRTY_BIT_DEPTH_FUNC);
Shannon Woods53a94a82014-06-24 15:20:36 -0400579}
580
581void State::setDepthRange(float zNear, float zFar)
582{
583 mNearZ = zNear;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700584 mFarZ = zFar;
Jamie Madill1b94d432015-08-07 13:23:23 -0400585 mDirtyBits.set(DIRTY_BIT_DEPTH_RANGE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400586}
587
Shannon Woods53a94a82014-06-24 15:20:36 -0400588void State::setBlend(bool enabled)
589{
590 mBlend.blend = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400591 mDirtyBits.set(DIRTY_BIT_BLEND_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400592}
593
594void State::setBlendFactors(GLenum sourceRGB, GLenum destRGB, GLenum sourceAlpha, GLenum destAlpha)
595{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700596 mBlend.sourceBlendRGB = sourceRGB;
597 mBlend.destBlendRGB = destRGB;
Shannon Woods53a94a82014-06-24 15:20:36 -0400598 mBlend.sourceBlendAlpha = sourceAlpha;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700599 mBlend.destBlendAlpha = destAlpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400600 mDirtyBits.set(DIRTY_BIT_BLEND_FUNCS);
Shannon Woods53a94a82014-06-24 15:20:36 -0400601}
602
603void State::setBlendColor(float red, float green, float blue, float alpha)
604{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700605 mBlendColor.red = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400606 mBlendColor.green = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700607 mBlendColor.blue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400608 mBlendColor.alpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400609 mDirtyBits.set(DIRTY_BIT_BLEND_COLOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400610}
611
612void State::setBlendEquation(GLenum rgbEquation, GLenum alphaEquation)
613{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700614 mBlend.blendEquationRGB = rgbEquation;
Shannon Woods53a94a82014-06-24 15:20:36 -0400615 mBlend.blendEquationAlpha = alphaEquation;
Jamie Madill1b94d432015-08-07 13:23:23 -0400616 mDirtyBits.set(DIRTY_BIT_BLEND_EQUATIONS);
Shannon Woods53a94a82014-06-24 15:20:36 -0400617}
618
Shannon Woods53a94a82014-06-24 15:20:36 -0400619void State::setStencilTest(bool enabled)
620{
621 mDepthStencil.stencilTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400622 mDirtyBits.set(DIRTY_BIT_STENCIL_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400623}
624
625void State::setStencilParams(GLenum stencilFunc, GLint stencilRef, GLuint stencilMask)
626{
627 mDepthStencil.stencilFunc = stencilFunc;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700628 mStencilRef = (stencilRef > 0) ? stencilRef : 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400629 mDepthStencil.stencilMask = stencilMask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400630 mDirtyBits.set(DIRTY_BIT_STENCIL_FUNCS_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400631}
632
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700633void State::setStencilBackParams(GLenum stencilBackFunc,
634 GLint stencilBackRef,
635 GLuint stencilBackMask)
Shannon Woods53a94a82014-06-24 15:20:36 -0400636{
637 mDepthStencil.stencilBackFunc = stencilBackFunc;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700638 mStencilBackRef = (stencilBackRef > 0) ? stencilBackRef : 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400639 mDepthStencil.stencilBackMask = stencilBackMask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400640 mDirtyBits.set(DIRTY_BIT_STENCIL_FUNCS_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400641}
642
643void State::setStencilWritemask(GLuint stencilWritemask)
644{
645 mDepthStencil.stencilWritemask = stencilWritemask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400646 mDirtyBits.set(DIRTY_BIT_STENCIL_WRITEMASK_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400647}
648
649void State::setStencilBackWritemask(GLuint stencilBackWritemask)
650{
651 mDepthStencil.stencilBackWritemask = stencilBackWritemask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400652 mDirtyBits.set(DIRTY_BIT_STENCIL_WRITEMASK_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400653}
654
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700655void State::setStencilOperations(GLenum stencilFail,
656 GLenum stencilPassDepthFail,
657 GLenum stencilPassDepthPass)
Shannon Woods53a94a82014-06-24 15:20:36 -0400658{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700659 mDepthStencil.stencilFail = stencilFail;
Shannon Woods53a94a82014-06-24 15:20:36 -0400660 mDepthStencil.stencilPassDepthFail = stencilPassDepthFail;
661 mDepthStencil.stencilPassDepthPass = stencilPassDepthPass;
Jamie Madill1b94d432015-08-07 13:23:23 -0400662 mDirtyBits.set(DIRTY_BIT_STENCIL_OPS_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400663}
664
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700665void State::setStencilBackOperations(GLenum stencilBackFail,
666 GLenum stencilBackPassDepthFail,
667 GLenum stencilBackPassDepthPass)
Shannon Woods53a94a82014-06-24 15:20:36 -0400668{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700669 mDepthStencil.stencilBackFail = stencilBackFail;
Shannon Woods53a94a82014-06-24 15:20:36 -0400670 mDepthStencil.stencilBackPassDepthFail = stencilBackPassDepthFail;
671 mDepthStencil.stencilBackPassDepthPass = stencilBackPassDepthPass;
Jamie Madill1b94d432015-08-07 13:23:23 -0400672 mDirtyBits.set(DIRTY_BIT_STENCIL_OPS_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400673}
674
Shannon Woods53a94a82014-06-24 15:20:36 -0400675void State::setPolygonOffsetFill(bool enabled)
676{
Jamie Madill1b94d432015-08-07 13:23:23 -0400677 mRasterizer.polygonOffsetFill = enabled;
678 mDirtyBits.set(DIRTY_BIT_POLYGON_OFFSET_FILL_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400679}
680
681void State::setPolygonOffsetParams(GLfloat factor, GLfloat units)
682{
683 // An application can pass NaN values here, so handle this gracefully
684 mRasterizer.polygonOffsetFactor = factor != factor ? 0.0f : factor;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700685 mRasterizer.polygonOffsetUnits = units != units ? 0.0f : units;
Jamie Madill1b94d432015-08-07 13:23:23 -0400686 mDirtyBits.set(DIRTY_BIT_POLYGON_OFFSET);
Shannon Woods53a94a82014-06-24 15:20:36 -0400687}
688
Shannon Woods53a94a82014-06-24 15:20:36 -0400689void State::setSampleAlphaToCoverage(bool enabled)
690{
691 mBlend.sampleAlphaToCoverage = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400692 mDirtyBits.set(DIRTY_BIT_SAMPLE_ALPHA_TO_COVERAGE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400693}
694
Shannon Woods53a94a82014-06-24 15:20:36 -0400695void State::setSampleCoverage(bool enabled)
696{
697 mSampleCoverage = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400698 mDirtyBits.set(DIRTY_BIT_SAMPLE_COVERAGE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400699}
700
701void State::setSampleCoverageParams(GLclampf value, bool invert)
702{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700703 mSampleCoverageValue = value;
Shannon Woods53a94a82014-06-24 15:20:36 -0400704 mSampleCoverageInvert = invert;
Jamie Madill1b94d432015-08-07 13:23:23 -0400705 mDirtyBits.set(DIRTY_BIT_SAMPLE_COVERAGE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400706}
707
Jiawei Shaodb342272017-09-27 10:21:45 +0800708void State::setSampleMaskEnabled(bool enabled)
709{
710 mSampleMask = enabled;
711 mDirtyBits.set(DIRTY_BIT_SAMPLE_MASK_ENABLED);
712}
713
714void State::setSampleMaskParams(GLuint maskNumber, GLbitfield mask)
715{
716 ASSERT(maskNumber < mMaxSampleMaskWords);
717 mSampleMaskValues[maskNumber] = mask;
Jamie Madillc67323a2017-11-02 23:11:41 -0400718 // TODO(jmadill): Use a child dirty bit if we ever use more than two words.
719 mDirtyBits.set(DIRTY_BIT_SAMPLE_MASK);
Jiawei Shaodb342272017-09-27 10:21:45 +0800720}
721
Sami Väisänen74c23472016-05-09 17:30:30 +0300722void State::setSampleAlphaToOne(bool enabled)
723{
724 mSampleAlphaToOne = enabled;
725 mDirtyBits.set(DIRTY_BIT_SAMPLE_ALPHA_TO_ONE);
726}
727
Sami Väisänen74c23472016-05-09 17:30:30 +0300728void State::setMultisampling(bool enabled)
729{
730 mMultiSampling = enabled;
731 mDirtyBits.set(DIRTY_BIT_MULTISAMPLING);
732}
733
Shannon Woods53a94a82014-06-24 15:20:36 -0400734void State::setScissorTest(bool enabled)
735{
736 mScissorTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400737 mDirtyBits.set(DIRTY_BIT_SCISSOR_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400738}
739
740void State::setScissorParams(GLint x, GLint y, GLsizei width, GLsizei height)
741{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700742 mScissor.x = x;
743 mScissor.y = y;
744 mScissor.width = width;
Shannon Woods53a94a82014-06-24 15:20:36 -0400745 mScissor.height = height;
Jamie Madill1b94d432015-08-07 13:23:23 -0400746 mDirtyBits.set(DIRTY_BIT_SCISSOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400747}
748
Shannon Woods53a94a82014-06-24 15:20:36 -0400749void State::setDither(bool enabled)
750{
751 mBlend.dither = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400752 mDirtyBits.set(DIRTY_BIT_DITHER_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400753}
754
Jamie Madillb4b53c52015-02-03 15:22:48 -0500755void State::setPrimitiveRestart(bool enabled)
756{
757 mPrimitiveRestart = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400758 mDirtyBits.set(DIRTY_BIT_PRIMITIVE_RESTART_ENABLED);
Jamie Madillb4b53c52015-02-03 15:22:48 -0500759}
760
Shannon Woods53a94a82014-06-24 15:20:36 -0400761void State::setEnableFeature(GLenum feature, bool enabled)
762{
763 switch (feature)
764 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700765 case GL_MULTISAMPLE_EXT:
766 setMultisampling(enabled);
767 break;
768 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
769 setSampleAlphaToOne(enabled);
770 break;
771 case GL_CULL_FACE:
772 setCullFace(enabled);
773 break;
774 case GL_POLYGON_OFFSET_FILL:
775 setPolygonOffsetFill(enabled);
776 break;
777 case GL_SAMPLE_ALPHA_TO_COVERAGE:
778 setSampleAlphaToCoverage(enabled);
779 break;
780 case GL_SAMPLE_COVERAGE:
781 setSampleCoverage(enabled);
782 break;
783 case GL_SCISSOR_TEST:
784 setScissorTest(enabled);
785 break;
786 case GL_STENCIL_TEST:
787 setStencilTest(enabled);
788 break;
789 case GL_DEPTH_TEST:
790 setDepthTest(enabled);
791 break;
792 case GL_BLEND:
793 setBlend(enabled);
794 break;
795 case GL_DITHER:
796 setDither(enabled);
797 break;
798 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
799 setPrimitiveRestart(enabled);
800 break;
801 case GL_RASTERIZER_DISCARD:
802 setRasterizerDiscard(enabled);
803 break;
804 case GL_SAMPLE_MASK:
805 setSampleMaskEnabled(enabled);
806 break;
807 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
808 mDebug.setOutputSynchronous(enabled);
809 break;
810 case GL_DEBUG_OUTPUT:
811 mDebug.setOutputEnabled(enabled);
812 break;
813 case GL_FRAMEBUFFER_SRGB_EXT:
814 setFramebufferSRGB(enabled);
815 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -0700816
817 // GLES1 emulation
818 case GL_ALPHA_TEST:
819 mGLES1State.mAlphaTestEnabled = enabled;
820 break;
Lingfeng Yang23dc90b2018-04-23 09:01:49 -0700821 case GL_TEXTURE_2D:
822 mGLES1State.mTexUnitEnables[mActiveSampler].set(TextureType::_2D, enabled);
823 break;
824 case GL_TEXTURE_CUBE_MAP:
825 mGLES1State.mTexUnitEnables[mActiveSampler].set(TextureType::CubeMap, enabled);
826 break;
Lingfeng Yangd0febe72018-05-17 22:36:52 -0700827 case GL_LIGHTING:
828 mGLES1State.mLightingEnabled = enabled;
829 break;
830 case GL_LIGHT0:
831 case GL_LIGHT1:
832 case GL_LIGHT2:
833 case GL_LIGHT3:
834 case GL_LIGHT4:
835 case GL_LIGHT5:
836 case GL_LIGHT6:
837 case GL_LIGHT7:
838 mGLES1State.mLights[feature - GL_LIGHT0].enabled = enabled;
839 break;
840 case GL_NORMALIZE:
841 mGLES1State.mNormalizeEnabled = enabled;
842 break;
843 case GL_RESCALE_NORMAL:
844 mGLES1State.mRescaleNormalEnabled = enabled;
845 break;
846 case GL_COLOR_MATERIAL:
847 mGLES1State.mColorMaterialEnabled = enabled;
848 break;
Lingfeng Yang060088a2018-05-30 20:40:57 -0700849 case GL_CLIP_PLANE0:
850 case GL_CLIP_PLANE1:
851 case GL_CLIP_PLANE2:
852 case GL_CLIP_PLANE3:
853 case GL_CLIP_PLANE4:
854 case GL_CLIP_PLANE5:
855 mGLES1State.mClipPlanes[feature - GL_CLIP_PLANE0].enabled = enabled;
856 break;
Lingfeng Yang7ba3f422018-06-01 09:43:04 -0700857 case GL_FOG:
858 mGLES1State.mFogEnabled = enabled;
859 break;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -0700860 case GL_POINT_SMOOTH:
861 mGLES1State.mPointSmoothEnabled = enabled;
862 break;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -0700863 case GL_LINE_SMOOTH:
864 mGLES1State.mLineSmoothEnabled = enabled;
865 break;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -0700866 case GL_POINT_SPRITE_OES:
867 mGLES1State.mPointSpriteEnabled = enabled;
868 break;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -0700869 case GL_COLOR_LOGIC_OP:
870 mGLES1State.mLogicOpEnabled = enabled;
871 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700872 default:
873 UNREACHABLE();
Shannon Woods53a94a82014-06-24 15:20:36 -0400874 }
875}
876
Jamie Madilldfde6ab2016-06-09 07:07:18 -0700877bool State::getEnableFeature(GLenum feature) const
Shannon Woods53a94a82014-06-24 15:20:36 -0400878{
879 switch (feature)
880 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700881 case GL_MULTISAMPLE_EXT:
882 return isMultisamplingEnabled();
883 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
884 return isSampleAlphaToOneEnabled();
885 case GL_CULL_FACE:
886 return isCullFaceEnabled();
887 case GL_POLYGON_OFFSET_FILL:
888 return isPolygonOffsetFillEnabled();
889 case GL_SAMPLE_ALPHA_TO_COVERAGE:
890 return isSampleAlphaToCoverageEnabled();
891 case GL_SAMPLE_COVERAGE:
892 return isSampleCoverageEnabled();
893 case GL_SCISSOR_TEST:
894 return isScissorTestEnabled();
895 case GL_STENCIL_TEST:
896 return isStencilTestEnabled();
897 case GL_DEPTH_TEST:
898 return isDepthTestEnabled();
899 case GL_BLEND:
900 return isBlendEnabled();
901 case GL_DITHER:
902 return isDitherEnabled();
903 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
904 return isPrimitiveRestartEnabled();
905 case GL_RASTERIZER_DISCARD:
906 return isRasterizerDiscardEnabled();
907 case GL_SAMPLE_MASK:
908 return isSampleMaskEnabled();
909 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
910 return mDebug.isOutputSynchronous();
911 case GL_DEBUG_OUTPUT:
912 return mDebug.isOutputEnabled();
913 case GL_BIND_GENERATES_RESOURCE_CHROMIUM:
914 return isBindGeneratesResourceEnabled();
915 case GL_CLIENT_ARRAYS_ANGLE:
916 return areClientArraysEnabled();
917 case GL_FRAMEBUFFER_SRGB_EXT:
918 return getFramebufferSRGB();
919 case GL_ROBUST_RESOURCE_INITIALIZATION_ANGLE:
920 return mRobustResourceInit;
921 case GL_PROGRAM_CACHE_ENABLED_ANGLE:
922 return mProgramBinaryCacheEnabled;
Jamie Madillc43be722017-07-13 16:22:14 -0400923
Lingfeng Yang13b708f2018-03-21 12:14:10 -0700924 // GLES1 emulation
925 case GL_ALPHA_TEST:
926 return mGLES1State.mAlphaTestEnabled;
Lingfeng Yang01074432018-04-16 10:19:51 -0700927 case GL_VERTEX_ARRAY:
928 return mGLES1State.mVertexArrayEnabled;
929 case GL_NORMAL_ARRAY:
930 return mGLES1State.mNormalArrayEnabled;
931 case GL_COLOR_ARRAY:
932 return mGLES1State.mColorArrayEnabled;
933 case GL_POINT_SIZE_ARRAY_OES:
934 return mGLES1State.mPointSizeArrayEnabled;
935 case GL_TEXTURE_COORD_ARRAY:
936 return mGLES1State.mTexCoordArrayEnabled[mGLES1State.mClientActiveTexture];
Lingfeng Yang23dc90b2018-04-23 09:01:49 -0700937 case GL_TEXTURE_2D:
938 return mGLES1State.mTexUnitEnables[mActiveSampler].test(TextureType::_2D);
939 case GL_TEXTURE_CUBE_MAP:
940 return mGLES1State.mTexUnitEnables[mActiveSampler].test(TextureType::CubeMap);
Lingfeng Yangd0febe72018-05-17 22:36:52 -0700941 case GL_LIGHTING:
942 return mGLES1State.mLightingEnabled;
943 case GL_LIGHT0:
944 case GL_LIGHT1:
945 case GL_LIGHT2:
946 case GL_LIGHT3:
947 case GL_LIGHT4:
948 case GL_LIGHT5:
949 case GL_LIGHT6:
950 case GL_LIGHT7:
951 return mGLES1State.mLights[feature - GL_LIGHT0].enabled;
952 case GL_NORMALIZE:
953 return mGLES1State.mNormalizeEnabled;
954 case GL_RESCALE_NORMAL:
955 return mGLES1State.mRescaleNormalEnabled;
956 case GL_COLOR_MATERIAL:
957 return mGLES1State.mColorMaterialEnabled;
Lingfeng Yang060088a2018-05-30 20:40:57 -0700958 case GL_CLIP_PLANE0:
959 case GL_CLIP_PLANE1:
960 case GL_CLIP_PLANE2:
961 case GL_CLIP_PLANE3:
962 case GL_CLIP_PLANE4:
963 case GL_CLIP_PLANE5:
964 return mGLES1State.mClipPlanes[feature - GL_CLIP_PLANE0].enabled;
Lingfeng Yang7ba3f422018-06-01 09:43:04 -0700965 case GL_FOG:
966 return mGLES1State.mFogEnabled;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -0700967 case GL_POINT_SMOOTH:
968 return mGLES1State.mPointSmoothEnabled;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -0700969 case GL_LINE_SMOOTH:
970 return mGLES1State.mLineSmoothEnabled;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -0700971 case GL_POINT_SPRITE_OES:
972 return mGLES1State.mPointSpriteEnabled;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -0700973 case GL_COLOR_LOGIC_OP:
974 return mGLES1State.mLogicOpEnabled;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700975 default:
976 UNREACHABLE();
977 return false;
Shannon Woods53a94a82014-06-24 15:20:36 -0400978 }
979}
980
981void State::setLineWidth(GLfloat width)
982{
983 mLineWidth = width;
Jamie Madill1b94d432015-08-07 13:23:23 -0400984 mDirtyBits.set(DIRTY_BIT_LINE_WIDTH);
Shannon Woods53a94a82014-06-24 15:20:36 -0400985}
986
987void State::setGenerateMipmapHint(GLenum hint)
988{
989 mGenerateMipmapHint = hint;
Jamie Madill1b94d432015-08-07 13:23:23 -0400990 mDirtyBits.set(DIRTY_BIT_GENERATE_MIPMAP_HINT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400991}
992
993void State::setFragmentShaderDerivativeHint(GLenum hint)
994{
995 mFragmentShaderDerivativeHint = hint;
Jamie Madill1b94d432015-08-07 13:23:23 -0400996 mDirtyBits.set(DIRTY_BIT_SHADER_DERIVATIVE_HINT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400997 // TODO: Propagate the hint to shader translator so we can write
998 // ddx, ddx_coarse, or ddx_fine depending on the hint.
999 // Ignore for now. It is valid for implementations to ignore hint.
1000}
1001
1002void State::setViewportParams(GLint x, GLint y, GLsizei width, GLsizei height)
1003{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001004 mViewport.x = x;
1005 mViewport.y = y;
1006 mViewport.width = width;
Shannon Woods53a94a82014-06-24 15:20:36 -04001007 mViewport.height = height;
Jamie Madill1b94d432015-08-07 13:23:23 -04001008 mDirtyBits.set(DIRTY_BIT_VIEWPORT);
Shannon Woods53a94a82014-06-24 15:20:36 -04001009}
1010
Shannon Woods53a94a82014-06-24 15:20:36 -04001011void State::setActiveSampler(unsigned int active)
1012{
1013 mActiveSampler = active;
1014}
1015
Jamie Madill526392d2018-11-16 09:35:14 -05001016angle::Result State::setSamplerTexture(const Context *context, TextureType type, Texture *texture)
Shannon Woods53a94a82014-06-24 15:20:36 -04001017{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001018 mSamplerTextures[type][mActiveSampler].set(context, texture);
Jamie Madill14246812018-10-03 17:51:16 -04001019
1020 if (mProgram && mProgram->getActiveSamplersMask()[mActiveSampler] &&
1021 mProgram->getActiveSamplerTypes()[mActiveSampler] == type)
1022 {
1023 ANGLE_TRY(updateActiveTexture(context, mActiveSampler, texture));
1024 }
1025
Jamie Madill81c2e252017-09-09 23:32:46 -04001026 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
Jamie Madill14246812018-10-03 17:51:16 -04001027
Jamie Madill526392d2018-11-16 09:35:14 -05001028 return angle::Result::Continue();
Shannon Woods53a94a82014-06-24 15:20:36 -04001029}
1030
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001031Texture *State::getTargetTexture(TextureType type) const
Jamie Madillc29968b2016-01-20 11:17:23 -05001032{
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001033 return getSamplerTexture(static_cast<unsigned int>(mActiveSampler), type);
Jamie Madillc29968b2016-01-20 11:17:23 -05001034}
1035
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001036GLuint State::getSamplerTextureId(unsigned int sampler, TextureType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001037{
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001038 ASSERT(sampler < mSamplerTextures[type].size());
1039 return mSamplerTextures[type][sampler].id();
Shannon Woods53a94a82014-06-24 15:20:36 -04001040}
1041
Jamie Madilla02315b2017-02-23 14:14:47 -05001042void State::detachTexture(const Context *context, const TextureMap &zeroTextures, GLuint texture)
Shannon Woods53a94a82014-06-24 15:20:36 -04001043{
1044 // Textures have a detach method on State rather than a simple
1045 // removeBinding, because the zero/null texture objects are managed
1046 // separately, and don't have to go through the Context's maps or
1047 // the ResourceManager.
1048
1049 // [OpenGL ES 2.0.24] section 3.8 page 84:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001050 // If a texture object is deleted, it is as if all texture units which are bound to that texture
1051 // object are rebound to texture object zero
Shannon Woods53a94a82014-06-24 15:20:36 -04001052
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001053 for (TextureType type : angle::AllEnums<TextureType>())
Shannon Woods53a94a82014-06-24 15:20:36 -04001054 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001055 TextureBindingVector &textureVector = mSamplerTextures[type];
Jamie Madill81c2e252017-09-09 23:32:46 -04001056 for (BindingPointer<Texture> &binding : textureVector)
Shannon Woods53a94a82014-06-24 15:20:36 -04001057 {
Geoff Lang76b10c92014-09-05 16:28:14 -04001058 if (binding.id() == texture)
Shannon Woods53a94a82014-06-24 15:20:36 -04001059 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001060 Texture *zeroTexture = zeroTextures[type].get();
1061 ASSERT(zeroTexture != nullptr);
Jamie Madille6382c32014-11-07 15:05:26 -05001062 // Zero textures are the "default" textures instead of NULL
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001063 binding.set(context, zeroTexture);
Jamie Madill81c2e252017-09-09 23:32:46 -04001064 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
Shannon Woods53a94a82014-06-24 15:20:36 -04001065 }
1066 }
1067 }
1068
Xinghua Cao65ec0b22017-03-28 16:10:52 +08001069 for (auto &bindingImageUnit : mImageUnits)
1070 {
1071 if (bindingImageUnit.texture.id() == texture)
1072 {
1073 bindingImageUnit.texture.set(context, nullptr);
1074 bindingImageUnit.level = 0;
1075 bindingImageUnit.layered = false;
1076 bindingImageUnit.layer = 0;
1077 bindingImageUnit.access = GL_READ_ONLY;
1078 bindingImageUnit.format = GL_R32UI;
1079 break;
1080 }
1081 }
1082
Shannon Woods53a94a82014-06-24 15:20:36 -04001083 // [OpenGL ES 2.0.24] section 4.4 page 112:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001084 // If a texture object is deleted while its image is attached to the currently bound
1085 // framebuffer, then it is as if Texture2DAttachment had been called, with a texture of 0, for
1086 // each attachment point to which this image was attached in the currently bound framebuffer.
Shannon Woods53a94a82014-06-24 15:20:36 -04001087
Jamie Madill8693bdb2017-09-02 15:32:14 -04001088 if (mReadFramebuffer && mReadFramebuffer->detachTexture(context, texture))
Shannon Woods53a94a82014-06-24 15:20:36 -04001089 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001090 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
Shannon Woods53a94a82014-06-24 15:20:36 -04001091 }
1092
Jamie Madill8693bdb2017-09-02 15:32:14 -04001093 if (mDrawFramebuffer && mDrawFramebuffer->detachTexture(context, texture))
Shannon Woods53a94a82014-06-24 15:20:36 -04001094 {
Jamie Madillef9fcd92018-11-28 14:03:59 -05001095 setDrawFramebufferDirty();
Shannon Woods53a94a82014-06-24 15:20:36 -04001096 }
1097}
1098
Jamie Madill4928b7c2017-06-20 12:57:39 -04001099void State::initializeZeroTextures(const Context *context, const TextureMap &zeroTextures)
Jamie Madille6382c32014-11-07 15:05:26 -05001100{
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001101 for (TextureType type : angle::AllEnums<TextureType>())
Jamie Madille6382c32014-11-07 15:05:26 -05001102 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001103 for (size_t textureUnit = 0; textureUnit < mSamplerTextures[type].size(); ++textureUnit)
Jamie Madille6382c32014-11-07 15:05:26 -05001104 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001105 mSamplerTextures[type][textureUnit].set(context, zeroTextures[type].get());
Jamie Madille6382c32014-11-07 15:05:26 -05001106 }
1107 }
1108}
1109
Jamie Madill4928b7c2017-06-20 12:57:39 -04001110void State::setSamplerBinding(const Context *context, GLuint textureUnit, Sampler *sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001111{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001112 mSamplers[textureUnit].set(context, sampler);
Jamie Madill81c2e252017-09-09 23:32:46 -04001113 mDirtyBits.set(DIRTY_BIT_SAMPLER_BINDINGS);
1114 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Jamie Madille25b8002018-09-20 13:39:49 -04001115 // This is overly conservative as it assumes the sampler has never been bound.
1116 setSamplerDirty(textureUnit);
Shannon Woods53a94a82014-06-24 15:20:36 -04001117}
1118
Jamie Madill4928b7c2017-06-20 12:57:39 -04001119void State::detachSampler(const Context *context, GLuint sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001120{
1121 // [OpenGL ES 3.0.2] section 3.8.2 pages 123-124:
1122 // If a sampler object that is currently bound to one or more texture units is
1123 // deleted, it is as though BindSampler is called once for each texture unit to
1124 // which the sampler is bound, with unit set to the texture unit and sampler set to zero.
Jamie Madill81c2e252017-09-09 23:32:46 -04001125 for (BindingPointer<Sampler> &samplerBinding : mSamplers)
Shannon Woods53a94a82014-06-24 15:20:36 -04001126 {
Geoff Lang76b10c92014-09-05 16:28:14 -04001127 if (samplerBinding.id() == sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001128 {
Jamie Madill4928b7c2017-06-20 12:57:39 -04001129 samplerBinding.set(context, nullptr);
Jamie Madill81c2e252017-09-09 23:32:46 -04001130 mDirtyBits.set(DIRTY_BIT_SAMPLER_BINDINGS);
Shannon Woods53a94a82014-06-24 15:20:36 -04001131 }
1132 }
1133}
1134
Jamie Madill4928b7c2017-06-20 12:57:39 -04001135void State::setRenderbufferBinding(const Context *context, Renderbuffer *renderbuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001136{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001137 mRenderbuffer.set(context, renderbuffer);
Jamie Madill8693bdb2017-09-02 15:32:14 -04001138 mDirtyBits.set(DIRTY_BIT_RENDERBUFFER_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001139}
1140
Jamie Madilla02315b2017-02-23 14:14:47 -05001141void State::detachRenderbuffer(const Context *context, GLuint renderbuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001142{
1143 // [OpenGL ES 2.0.24] section 4.4 page 109:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001144 // If a renderbuffer that is currently bound to RENDERBUFFER is deleted, it is as though
1145 // BindRenderbuffer had been executed with the target RENDERBUFFER and name of zero.
Shannon Woods53a94a82014-06-24 15:20:36 -04001146
1147 if (mRenderbuffer.id() == renderbuffer)
1148 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001149 setRenderbufferBinding(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001150 }
1151
1152 // [OpenGL ES 2.0.24] section 4.4 page 111:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001153 // If a renderbuffer object is deleted while its image is attached to the currently bound
1154 // framebuffer, then it is as if FramebufferRenderbuffer had been called, with a renderbuffer of
1155 // 0, for each attachment point to which this image was attached in the currently bound
1156 // framebuffer.
Shannon Woods53a94a82014-06-24 15:20:36 -04001157
1158 Framebuffer *readFramebuffer = mReadFramebuffer;
1159 Framebuffer *drawFramebuffer = mDrawFramebuffer;
1160
Jamie Madill8693bdb2017-09-02 15:32:14 -04001161 if (readFramebuffer && readFramebuffer->detachRenderbuffer(context, renderbuffer))
Shannon Woods53a94a82014-06-24 15:20:36 -04001162 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001163 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
Shannon Woods53a94a82014-06-24 15:20:36 -04001164 }
1165
1166 if (drawFramebuffer && drawFramebuffer != readFramebuffer)
1167 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001168 if (drawFramebuffer->detachRenderbuffer(context, renderbuffer))
1169 {
Jamie Madillef9fcd92018-11-28 14:03:59 -05001170 setDrawFramebufferDirty();
Jamie Madill8693bdb2017-09-02 15:32:14 -04001171 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001172 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001173}
1174
1175void State::setReadFramebufferBinding(Framebuffer *framebuffer)
1176{
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001177 if (mReadFramebuffer == framebuffer)
1178 return;
1179
Shannon Woods53a94a82014-06-24 15:20:36 -04001180 mReadFramebuffer = framebuffer;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001181 mDirtyBits.set(DIRTY_BIT_READ_FRAMEBUFFER_BINDING);
1182
1183 if (mReadFramebuffer && mReadFramebuffer->hasAnyDirtyBit())
1184 {
1185 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
1186 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001187}
1188
1189void State::setDrawFramebufferBinding(Framebuffer *framebuffer)
1190{
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001191 if (mDrawFramebuffer == framebuffer)
1192 return;
1193
Shannon Woods53a94a82014-06-24 15:20:36 -04001194 mDrawFramebuffer = framebuffer;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001195 mDirtyBits.set(DIRTY_BIT_DRAW_FRAMEBUFFER_BINDING);
1196
Jamie Madillef9fcd92018-11-28 14:03:59 -05001197 if (mDrawFramebuffer)
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001198 {
Jamie Madillef9fcd92018-11-28 14:03:59 -05001199 if (mDrawFramebuffer->hasAnyDirtyBit())
1200 {
1201 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
1202 }
1203
1204 if (mRobustResourceInit && mDrawFramebuffer->hasResourceThatNeedsInit())
1205 {
1206 mDirtyObjects.set(DIRTY_OBJECT_DRAW_ATTACHMENTS);
1207 }
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001208 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001209}
1210
1211Framebuffer *State::getTargetFramebuffer(GLenum target) const
1212{
1213 switch (target)
1214 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001215 case GL_READ_FRAMEBUFFER_ANGLE:
1216 return mReadFramebuffer;
1217 case GL_DRAW_FRAMEBUFFER_ANGLE:
1218 case GL_FRAMEBUFFER:
1219 return mDrawFramebuffer;
1220 default:
1221 UNREACHABLE();
Yunchao Hef81ce4a2017-04-24 10:49:17 +08001222 return nullptr;
Shannon Woods53a94a82014-06-24 15:20:36 -04001223 }
1224}
1225
Shannon Woods53a94a82014-06-24 15:20:36 -04001226bool State::removeReadFramebufferBinding(GLuint framebuffer)
1227{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001228 if (mReadFramebuffer != nullptr && mReadFramebuffer->id() == framebuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001229 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001230 setReadFramebufferBinding(nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001231 return true;
1232 }
1233
1234 return false;
1235}
1236
1237bool State::removeDrawFramebufferBinding(GLuint framebuffer)
1238{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001239 if (mReadFramebuffer != nullptr && mDrawFramebuffer->id() == framebuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001240 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001241 setDrawFramebufferBinding(nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001242 return true;
1243 }
1244
1245 return false;
1246}
1247
Jamie Madill7267aa62018-04-17 15:28:21 -04001248void State::setVertexArrayBinding(const Context *context, VertexArray *vertexArray)
Shannon Woods53a94a82014-06-24 15:20:36 -04001249{
James Darpiniane8a93c62018-01-04 18:02:24 -08001250 if (mVertexArray == vertexArray)
1251 return;
1252 if (mVertexArray)
Jamie Madillbf5177d2018-08-21 12:58:20 -04001253 mVertexArray->onBindingChanged(context, -1);
Shannon Woods53a94a82014-06-24 15:20:36 -04001254 mVertexArray = vertexArray;
James Darpiniane8a93c62018-01-04 18:02:24 -08001255 if (vertexArray)
Jamie Madillbf5177d2018-08-21 12:58:20 -04001256 vertexArray->onBindingChanged(context, 1);
Jamie Madill0b9e9032015-08-17 11:51:52 +00001257 mDirtyBits.set(DIRTY_BIT_VERTEX_ARRAY_BINDING);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001258
1259 if (mVertexArray && mVertexArray->hasAnyDirtyBit())
1260 {
1261 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1262 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001263}
1264
Jamie Madill7267aa62018-04-17 15:28:21 -04001265bool State::removeVertexArrayBinding(const Context *context, GLuint vertexArray)
Shannon Woods53a94a82014-06-24 15:20:36 -04001266{
James Darpiniane8a93c62018-01-04 18:02:24 -08001267 if (mVertexArray && mVertexArray->id() == vertexArray)
Shannon Woods53a94a82014-06-24 15:20:36 -04001268 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001269 mVertexArray->onBindingChanged(context, -1);
Yunchao Hed7297bf2017-04-19 15:27:10 +08001270 mVertexArray = nullptr;
Jamie Madill0b9e9032015-08-17 11:51:52 +00001271 mDirtyBits.set(DIRTY_BIT_VERTEX_ARRAY_BINDING);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001272 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001273 return true;
1274 }
1275
1276 return false;
1277}
1278
Markus Tavenrath774fe562018-11-18 14:14:49 +01001279GLuint State::getVertexArrayId() const
1280{
1281 ASSERT(mVertexArray != nullptr);
1282 return mVertexArray->id();
1283}
1284
Jamie Madill4928b7c2017-06-20 12:57:39 -04001285void State::bindVertexBuffer(const Context *context,
1286 GLuint bindingIndex,
Shao80957d92017-02-20 21:25:59 +08001287 Buffer *boundBuffer,
1288 GLintptr offset,
1289 GLsizei stride)
1290{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001291 getVertexArray()->bindVertexBuffer(context, bindingIndex, boundBuffer, offset, stride);
Shao80957d92017-02-20 21:25:59 +08001292 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1293}
1294
Shaodde78e82017-05-22 14:13:27 +08001295void State::setVertexAttribBinding(const Context *context, GLuint attribIndex, GLuint bindingIndex)
Shao80957d92017-02-20 21:25:59 +08001296{
Shaodde78e82017-05-22 14:13:27 +08001297 getVertexArray()->setVertexAttribBinding(context, attribIndex, bindingIndex);
Shao80957d92017-02-20 21:25:59 +08001298 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1299}
1300
1301void State::setVertexAttribFormat(GLuint attribIndex,
1302 GLint size,
1303 GLenum type,
1304 bool normalized,
1305 bool pureInteger,
1306 GLuint relativeOffset)
1307{
1308 getVertexArray()->setVertexAttribFormat(attribIndex, size, type, normalized, pureInteger,
1309 relativeOffset);
1310 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1311}
1312
1313void State::setVertexBindingDivisor(GLuint bindingIndex, GLuint divisor)
1314{
1315 getVertexArray()->setVertexBindingDivisor(bindingIndex, divisor);
1316 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1317}
1318
Jamie Madill6f755b22018-10-09 12:48:54 -04001319angle::Result State::setProgram(const Context *context, Program *newProgram)
Shannon Woods53a94a82014-06-24 15:20:36 -04001320{
Geoff Lang7dd2e102014-11-10 15:19:26 -05001321 if (mProgram != newProgram)
Shannon Woods53a94a82014-06-24 15:20:36 -04001322 {
Geoff Lang7dd2e102014-11-10 15:19:26 -05001323 if (mProgram)
1324 {
Jamie Madille3bb6b72018-10-03 17:51:15 -04001325 unsetActiveTextures(mProgram->getActiveSamplersMask());
Jamie Madill6c1f6712017-02-14 19:08:04 -05001326 mProgram->release(context);
Geoff Lang7dd2e102014-11-10 15:19:26 -05001327 }
1328
1329 mProgram = newProgram;
1330
1331 if (mProgram)
1332 {
1333 newProgram->addRef();
Jamie Madille3bb6b72018-10-03 17:51:15 -04001334 ANGLE_TRY(onProgramExecutableChange(context, newProgram));
Geoff Lang7dd2e102014-11-10 15:19:26 -05001335 }
Jamie Madilldf836ff2018-10-01 10:36:24 -04001336
1337 // Note that rendering is undefined if glUseProgram(0) is called. But ANGLE will generate
1338 // an error if the app tries to draw in this case.
1339
Jamie Madilla779b612017-07-24 11:46:05 -04001340 mDirtyBits.set(DIRTY_BIT_PROGRAM_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001341 }
Jamie Madille3bb6b72018-10-03 17:51:15 -04001342
Jamie Madill6f755b22018-10-09 12:48:54 -04001343 return angle::Result::Continue();
Shannon Woods53a94a82014-06-24 15:20:36 -04001344}
1345
Jamie Madill4928b7c2017-06-20 12:57:39 -04001346void State::setTransformFeedbackBinding(const Context *context,
1347 TransformFeedback *transformFeedback)
Shannon Woods53a94a82014-06-24 15:20:36 -04001348{
James Darpiniane8a93c62018-01-04 18:02:24 -08001349 if (transformFeedback == mTransformFeedback.get())
1350 return;
1351 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -04001352 mTransformFeedback->onBindingChanged(context, false);
Jamie Madill4928b7c2017-06-20 12:57:39 -04001353 mTransformFeedback.set(context, transformFeedback);
James Darpiniane8a93c62018-01-04 18:02:24 -08001354 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -04001355 mTransformFeedback->onBindingChanged(context, true);
Geoff Langded79232017-11-28 15:21:11 -05001356 mDirtyBits.set(DIRTY_BIT_TRANSFORM_FEEDBACK_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001357}
1358
Jamie Madill4928b7c2017-06-20 12:57:39 -04001359bool State::removeTransformFeedbackBinding(const Context *context, GLuint transformFeedback)
Shannon Woods53a94a82014-06-24 15:20:36 -04001360{
1361 if (mTransformFeedback.id() == transformFeedback)
1362 {
James Darpiniane8a93c62018-01-04 18:02:24 -08001363 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -04001364 mTransformFeedback->onBindingChanged(context, false);
Jamie Madill4928b7c2017-06-20 12:57:39 -04001365 mTransformFeedback.set(context, nullptr);
Corentin Walleza2257da2016-04-19 16:43:12 -04001366 return true;
Shannon Woods53a94a82014-06-24 15:20:36 -04001367 }
Corentin Walleza2257da2016-04-19 16:43:12 -04001368
1369 return false;
Shannon Woods53a94a82014-06-24 15:20:36 -04001370}
1371
Yunchao Hea336b902017-08-02 16:05:21 +08001372void State::setProgramPipelineBinding(const Context *context, ProgramPipeline *pipeline)
1373{
1374 mProgramPipeline.set(context, pipeline);
1375}
1376
1377void State::detachProgramPipeline(const Context *context, GLuint pipeline)
1378{
1379 mProgramPipeline.set(context, nullptr);
1380}
1381
Corentin Wallezad3ae902018-03-09 13:40:42 -05001382bool State::isQueryActive(QueryType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001383{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001384 const Query *query = mActiveQueries[type].get();
1385 if (query != nullptr)
Shannon Woods53a94a82014-06-24 15:20:36 -04001386 {
Corentin Wallezad3ae902018-03-09 13:40:42 -05001387 return true;
1388 }
1389
1390 QueryType alternativeType;
1391 if (GetAlternativeQueryType(type, &alternativeType))
1392 {
1393 query = mActiveQueries[alternativeType].get();
1394 return query != nullptr;
Ian Ewell3ffd78b2016-01-22 16:09:42 -05001395 }
1396
1397 return false;
1398}
1399
1400bool State::isQueryActive(Query *query) const
1401{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001402 for (auto &queryPointer : mActiveQueries)
Ian Ewell3ffd78b2016-01-22 16:09:42 -05001403 {
Corentin Wallezad3ae902018-03-09 13:40:42 -05001404 if (queryPointer.get() == query)
Shannon Woods53a94a82014-06-24 15:20:36 -04001405 {
1406 return true;
1407 }
1408 }
1409
1410 return false;
1411}
1412
Corentin Wallezad3ae902018-03-09 13:40:42 -05001413void State::setActiveQuery(const Context *context, QueryType type, Query *query)
Shannon Woods53a94a82014-06-24 15:20:36 -04001414{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001415 mActiveQueries[type].set(context, query);
Shannon Woods53a94a82014-06-24 15:20:36 -04001416}
1417
Corentin Wallezad3ae902018-03-09 13:40:42 -05001418GLuint State::getActiveQueryId(QueryType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001419{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001420 const Query *query = getActiveQuery(type);
Shannon Woods53a94a82014-06-24 15:20:36 -04001421 return (query ? query->id() : 0u);
1422}
1423
Corentin Wallezad3ae902018-03-09 13:40:42 -05001424Query *State::getActiveQuery(QueryType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001425{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001426 return mActiveQueries[type].get();
Shannon Woods53a94a82014-06-24 15:20:36 -04001427}
1428
Corentin Wallez336129f2017-10-17 15:55:40 -04001429void State::setIndexedBufferBinding(const Context *context,
1430 BufferBinding target,
1431 GLuint index,
1432 Buffer *buffer,
1433 GLintptr offset,
1434 GLsizeiptr size)
Jiajia Qin9d7d0b12016-11-29 16:30:31 +08001435{
Corentin Wallez336129f2017-10-17 15:55:40 -04001436 setBufferBinding(context, target, buffer);
Jiajia Qin9d7d0b12016-11-29 16:30:31 +08001437
Corentin Wallez336129f2017-10-17 15:55:40 -04001438 switch (target)
1439 {
1440 case BufferBinding::TransformFeedback:
1441 mTransformFeedback->bindIndexedBuffer(context, index, buffer, offset, size);
James Darpiniane8a93c62018-01-04 18:02:24 -08001442 setBufferBinding(context, target, buffer);
Corentin Wallez336129f2017-10-17 15:55:40 -04001443 break;
1444 case BufferBinding::Uniform:
Jamie Madillbf5177d2018-08-21 12:58:20 -04001445 UpdateIndexedBufferBinding(context, &mUniformBuffers[index], buffer, target, offset,
1446 size);
Corentin Wallez336129f2017-10-17 15:55:40 -04001447 break;
1448 case BufferBinding::AtomicCounter:
Jamie Madillbf5177d2018-08-21 12:58:20 -04001449 UpdateIndexedBufferBinding(context, &mAtomicCounterBuffers[index], buffer, target,
1450 offset, size);
Corentin Wallez336129f2017-10-17 15:55:40 -04001451 break;
1452 case BufferBinding::ShaderStorage:
Jamie Madillbf5177d2018-08-21 12:58:20 -04001453 UpdateIndexedBufferBinding(context, &mShaderStorageBuffers[index], buffer, target,
1454 offset, size);
Corentin Wallez336129f2017-10-17 15:55:40 -04001455 break;
1456 default:
1457 UNREACHABLE();
1458 break;
1459 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001460}
1461
Geoff Lang5d124a62015-09-15 13:03:27 -04001462const OffsetBindingPointer<Buffer> &State::getIndexedUniformBuffer(size_t index) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001463{
Shannon Woodsf3acaf92014-09-23 18:07:11 -04001464 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
Geoff Lang5d124a62015-09-15 13:03:27 -04001465 return mUniformBuffers[index];
Gregoire Payen de La Garanderie68694e92015-03-24 14:03:37 +00001466}
1467
Jiajia Qin6eafb042016-12-27 17:04:07 +08001468const OffsetBindingPointer<Buffer> &State::getIndexedAtomicCounterBuffer(size_t index) const
1469{
1470 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
1471 return mAtomicCounterBuffers[index];
1472}
1473
Jiajia Qinf546e7d2017-03-27 14:12:59 +08001474const OffsetBindingPointer<Buffer> &State::getIndexedShaderStorageBuffer(size_t index) const
1475{
1476 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
1477 return mShaderStorageBuffers[index];
1478}
1479
Corentin Wallez336129f2017-10-17 15:55:40 -04001480Buffer *State::getTargetBuffer(BufferBinding target) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001481{
1482 switch (target)
1483 {
Corentin Wallez336129f2017-10-17 15:55:40 -04001484 case BufferBinding::ElementArray:
Jamie Madillcd0a0a32018-10-18 18:41:57 -04001485 return getVertexArray()->getElementArrayBuffer();
Corentin Wallez336129f2017-10-17 15:55:40 -04001486 default:
1487 return mBoundBuffers[target].get();
Shannon Woods53a94a82014-06-24 15:20:36 -04001488 }
1489}
1490
James Darpinian4d9d4832018-03-13 12:43:28 -07001491void State::detachBuffer(const Context *context, const Buffer *buffer)
Yuly Novikov5807a532015-12-03 13:01:22 -05001492{
James Darpinian4d9d4832018-03-13 12:43:28 -07001493 if (!buffer->isBound())
1494 {
1495 return;
1496 }
1497 GLuint bufferName = buffer->id();
James Darpiniane8a93c62018-01-04 18:02:24 -08001498 for (auto target : angle::AllEnums<BufferBinding>())
Yuly Novikov5807a532015-12-03 13:01:22 -05001499 {
James Darpiniane8a93c62018-01-04 18:02:24 -08001500 if (mBoundBuffers[target].id() == bufferName)
Yuly Novikov5807a532015-12-03 13:01:22 -05001501 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001502 UpdateBufferBinding(context, &mBoundBuffers[target], nullptr, target);
Yuly Novikov5807a532015-12-03 13:01:22 -05001503 }
1504 }
1505
1506 TransformFeedback *curTransformFeedback = getCurrentTransformFeedback();
1507 if (curTransformFeedback)
1508 {
Jamie Madill4928b7c2017-06-20 12:57:39 -04001509 curTransformFeedback->detachBuffer(context, bufferName);
Yuly Novikov5807a532015-12-03 13:01:22 -05001510 }
1511
Jamie Madill4928b7c2017-06-20 12:57:39 -04001512 getVertexArray()->detachBuffer(context, bufferName);
James Darpiniane8a93c62018-01-04 18:02:24 -08001513
1514 for (auto &buf : mUniformBuffers)
1515 {
1516 if (buf.id() == bufferName)
1517 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001518 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::Uniform, 0, 0);
James Darpiniane8a93c62018-01-04 18:02:24 -08001519 }
1520 }
1521
1522 for (auto &buf : mAtomicCounterBuffers)
1523 {
1524 if (buf.id() == bufferName)
1525 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001526 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::AtomicCounter, 0, 0);
James Darpiniane8a93c62018-01-04 18:02:24 -08001527 }
1528 }
1529
1530 for (auto &buf : mShaderStorageBuffers)
1531 {
1532 if (buf.id() == bufferName)
1533 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001534 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::ShaderStorage, 0, 0);
James Darpiniane8a93c62018-01-04 18:02:24 -08001535 }
1536 }
Yuly Novikov5807a532015-12-03 13:01:22 -05001537}
1538
Shannon Woods53a94a82014-06-24 15:20:36 -04001539void State::setEnableVertexAttribArray(unsigned int attribNum, bool enabled)
1540{
1541 getVertexArray()->enableAttribute(attribNum, enabled);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001542 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001543}
1544
1545void State::setVertexAttribf(GLuint index, const GLfloat values[4])
1546{
Shannon Woods23e05002014-09-22 19:07:27 -04001547 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001548 mVertexAttribCurrentValues[index].setFloatValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001549 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1550 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001551 mCurrentValuesTypeMask.setIndex(GL_FLOAT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001552}
1553
1554void State::setVertexAttribu(GLuint index, const GLuint values[4])
1555{
Shannon Woods23e05002014-09-22 19:07:27 -04001556 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001557 mVertexAttribCurrentValues[index].setUnsignedIntValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001558 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1559 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001560 mCurrentValuesTypeMask.setIndex(GL_UNSIGNED_INT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001561}
1562
1563void State::setVertexAttribi(GLuint index, const GLint values[4])
1564{
Shannon Woods23e05002014-09-22 19:07:27 -04001565 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001566 mVertexAttribCurrentValues[index].setIntValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001567 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1568 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001569 mCurrentValuesTypeMask.setIndex(GL_INT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001570}
1571
Shaodde78e82017-05-22 14:13:27 +08001572void State::setVertexAttribPointer(const Context *context,
1573 unsigned int attribNum,
1574 Buffer *boundBuffer,
1575 GLint size,
1576 GLenum type,
1577 bool normalized,
1578 bool pureInteger,
1579 GLsizei stride,
1580 const void *pointer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001581{
Shaodde78e82017-05-22 14:13:27 +08001582 getVertexArray()->setVertexAttribPointer(context, attribNum, boundBuffer, size, type,
1583 normalized, pureInteger, stride, pointer);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001584 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Jamie Madill0b9e9032015-08-17 11:51:52 +00001585}
1586
Shaodde78e82017-05-22 14:13:27 +08001587void State::setVertexAttribDivisor(const Context *context, GLuint index, GLuint divisor)
Jamie Madill0b9e9032015-08-17 11:51:52 +00001588{
Shaodde78e82017-05-22 14:13:27 +08001589 getVertexArray()->setVertexAttribDivisor(context, index, divisor);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001590 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001591}
1592
Shannon Woods53a94a82014-06-24 15:20:36 -04001593const void *State::getVertexAttribPointer(unsigned int attribNum) const
1594{
1595 return getVertexArray()->getVertexAttribute(attribNum).pointer;
1596}
1597
1598void State::setPackAlignment(GLint alignment)
1599{
1600 mPack.alignment = alignment;
Jamie Madillc67323a2017-11-02 23:11:41 -04001601 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001602}
1603
Shannon Woods53a94a82014-06-24 15:20:36 -04001604void State::setPackReverseRowOrder(bool reverseRowOrder)
1605{
1606 mPack.reverseRowOrder = reverseRowOrder;
Jamie Madillc67323a2017-11-02 23:11:41 -04001607 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001608}
1609
Minmin Gongadff67b2015-10-14 10:34:45 -04001610void State::setPackRowLength(GLint rowLength)
1611{
1612 mPack.rowLength = rowLength;
Jamie Madillc67323a2017-11-02 23:11:41 -04001613 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001614}
1615
Minmin Gongadff67b2015-10-14 10:34:45 -04001616void State::setPackSkipRows(GLint skipRows)
1617{
1618 mPack.skipRows = skipRows;
Jamie Madillc67323a2017-11-02 23:11:41 -04001619 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001620}
1621
Minmin Gongadff67b2015-10-14 10:34:45 -04001622void State::setPackSkipPixels(GLint skipPixels)
1623{
1624 mPack.skipPixels = skipPixels;
Jamie Madillc67323a2017-11-02 23:11:41 -04001625 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001626}
1627
Shannon Woods53a94a82014-06-24 15:20:36 -04001628void State::setUnpackAlignment(GLint alignment)
1629{
1630 mUnpack.alignment = alignment;
Jamie Madillc67323a2017-11-02 23:11:41 -04001631 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001632}
1633
Minmin Gongb8aee3b2015-01-27 14:42:36 -08001634void State::setUnpackRowLength(GLint rowLength)
1635{
1636 mUnpack.rowLength = rowLength;
Jamie Madillc67323a2017-11-02 23:11:41 -04001637 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongb8aee3b2015-01-27 14:42:36 -08001638}
1639
Minmin Gongadff67b2015-10-14 10:34:45 -04001640void State::setUnpackImageHeight(GLint imageHeight)
1641{
1642 mUnpack.imageHeight = imageHeight;
Jamie Madillc67323a2017-11-02 23:11:41 -04001643 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001644}
1645
Minmin Gongadff67b2015-10-14 10:34:45 -04001646void State::setUnpackSkipImages(GLint skipImages)
1647{
1648 mUnpack.skipImages = skipImages;
Jamie Madillc67323a2017-11-02 23:11:41 -04001649 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001650}
1651
Minmin Gongadff67b2015-10-14 10:34:45 -04001652void State::setUnpackSkipRows(GLint skipRows)
1653{
1654 mUnpack.skipRows = skipRows;
Jamie Madillc67323a2017-11-02 23:11:41 -04001655 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001656}
1657
Minmin Gongadff67b2015-10-14 10:34:45 -04001658void State::setUnpackSkipPixels(GLint skipPixels)
1659{
1660 mUnpack.skipPixels = skipPixels;
Jamie Madillc67323a2017-11-02 23:11:41 -04001661 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001662}
1663
Sami Väisänena797e062016-05-12 15:23:40 +03001664void State::setCoverageModulation(GLenum components)
1665{
1666 mCoverageModulation = components;
1667 mDirtyBits.set(DIRTY_BIT_COVERAGE_MODULATION);
1668}
1669
Sami Väisänene45e53b2016-05-25 10:36:04 +03001670void State::loadPathRenderingMatrix(GLenum matrixMode, const GLfloat *matrix)
1671{
1672 if (matrixMode == GL_PATH_MODELVIEW_CHROMIUM)
1673 {
1674 memcpy(mPathMatrixMV, matrix, 16 * sizeof(GLfloat));
jchen10bb2f2c42018-09-16 09:47:38 +08001675 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING);
Sami Väisänene45e53b2016-05-25 10:36:04 +03001676 }
1677 else if (matrixMode == GL_PATH_PROJECTION_CHROMIUM)
1678 {
1679 memcpy(mPathMatrixProj, matrix, 16 * sizeof(GLfloat));
jchen10bb2f2c42018-09-16 09:47:38 +08001680 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING);
Sami Väisänene45e53b2016-05-25 10:36:04 +03001681 }
1682 else
1683 {
1684 UNREACHABLE();
1685 }
1686}
1687
1688const GLfloat *State::getPathRenderingMatrix(GLenum which) const
1689{
1690 if (which == GL_PATH_MODELVIEW_MATRIX_CHROMIUM)
1691 {
1692 return mPathMatrixMV;
1693 }
1694 else if (which == GL_PATH_PROJECTION_MATRIX_CHROMIUM)
1695 {
1696 return mPathMatrixProj;
1697 }
1698
1699 UNREACHABLE();
1700 return nullptr;
1701}
1702
1703void State::setPathStencilFunc(GLenum func, GLint ref, GLuint mask)
1704{
1705 mPathStencilFunc = func;
1706 mPathStencilRef = ref;
1707 mPathStencilMask = mask;
jchen10bb2f2c42018-09-16 09:47:38 +08001708 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING);
Sami Väisänene45e53b2016-05-25 10:36:04 +03001709}
1710
Geoff Lang1d2c41d2016-10-19 16:14:46 -07001711void State::setFramebufferSRGB(bool sRGB)
1712{
1713 mFramebufferSRGB = sRGB;
1714 mDirtyBits.set(DIRTY_BIT_FRAMEBUFFER_SRGB);
1715}
1716
jchen1082af6202018-06-22 10:59:52 +08001717void State::setMaxShaderCompilerThreads(GLuint count)
1718{
1719 mMaxShaderCompilerThreads = count;
1720}
1721
Shannon Woods53a94a82014-06-24 15:20:36 -04001722void State::getBooleanv(GLenum pname, GLboolean *params)
1723{
1724 switch (pname)
1725 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001726 case GL_SAMPLE_COVERAGE_INVERT:
1727 *params = mSampleCoverageInvert;
1728 break;
1729 case GL_DEPTH_WRITEMASK:
1730 *params = mDepthStencil.depthMask;
1731 break;
1732 case GL_COLOR_WRITEMASK:
1733 params[0] = mBlend.colorMaskRed;
1734 params[1] = mBlend.colorMaskGreen;
1735 params[2] = mBlend.colorMaskBlue;
1736 params[3] = mBlend.colorMaskAlpha;
1737 break;
1738 case GL_CULL_FACE:
1739 *params = mRasterizer.cullFace;
1740 break;
1741 case GL_POLYGON_OFFSET_FILL:
1742 *params = mRasterizer.polygonOffsetFill;
1743 break;
1744 case GL_SAMPLE_ALPHA_TO_COVERAGE:
1745 *params = mBlend.sampleAlphaToCoverage;
1746 break;
1747 case GL_SAMPLE_COVERAGE:
1748 *params = mSampleCoverage;
1749 break;
1750 case GL_SAMPLE_MASK:
1751 *params = mSampleMask;
1752 break;
1753 case GL_SCISSOR_TEST:
1754 *params = mScissorTest;
1755 break;
1756 case GL_STENCIL_TEST:
1757 *params = mDepthStencil.stencilTest;
1758 break;
1759 case GL_DEPTH_TEST:
1760 *params = mDepthStencil.depthTest;
1761 break;
1762 case GL_BLEND:
1763 *params = mBlend.blend;
1764 break;
1765 case GL_DITHER:
1766 *params = mBlend.dither;
1767 break;
1768 case GL_TRANSFORM_FEEDBACK_ACTIVE:
1769 *params = getCurrentTransformFeedback()->isActive() ? GL_TRUE : GL_FALSE;
1770 break;
1771 case GL_TRANSFORM_FEEDBACK_PAUSED:
1772 *params = getCurrentTransformFeedback()->isPaused() ? GL_TRUE : GL_FALSE;
1773 break;
1774 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
1775 *params = mPrimitiveRestart;
1776 break;
1777 case GL_RASTERIZER_DISCARD:
1778 *params = isRasterizerDiscardEnabled() ? GL_TRUE : GL_FALSE;
1779 break;
1780 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
1781 *params = mDebug.isOutputSynchronous() ? GL_TRUE : GL_FALSE;
1782 break;
1783 case GL_DEBUG_OUTPUT:
1784 *params = mDebug.isOutputEnabled() ? GL_TRUE : GL_FALSE;
1785 break;
1786 case GL_MULTISAMPLE_EXT:
1787 *params = mMultiSampling;
1788 break;
1789 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
1790 *params = mSampleAlphaToOne;
1791 break;
1792 case GL_BIND_GENERATES_RESOURCE_CHROMIUM:
1793 *params = isBindGeneratesResourceEnabled() ? GL_TRUE : GL_FALSE;
1794 break;
1795 case GL_CLIENT_ARRAYS_ANGLE:
1796 *params = areClientArraysEnabled() ? GL_TRUE : GL_FALSE;
1797 break;
1798 case GL_FRAMEBUFFER_SRGB_EXT:
1799 *params = getFramebufferSRGB() ? GL_TRUE : GL_FALSE;
1800 break;
1801 case GL_ROBUST_RESOURCE_INITIALIZATION_ANGLE:
1802 *params = mRobustResourceInit ? GL_TRUE : GL_FALSE;
1803 break;
1804 case GL_PROGRAM_CACHE_ENABLED_ANGLE:
1805 *params = mProgramBinaryCacheEnabled ? GL_TRUE : GL_FALSE;
1806 break;
Lingfeng Yangd0febe72018-05-17 22:36:52 -07001807 case GL_LIGHT_MODEL_TWO_SIDE:
1808 *params = IsLightModelTwoSided(&mGLES1State);
1809 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001810 default:
1811 UNREACHABLE();
1812 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04001813 }
1814}
1815
1816void State::getFloatv(GLenum pname, GLfloat *params)
1817{
1818 // Please note: DEPTH_CLEAR_VALUE is included in our internal getFloatv implementation
1819 // because it is stored as a float, despite the fact that the GL ES 2.0 spec names
1820 // GetIntegerv as its native query function. As it would require conversion in any
1821 // case, this should make no difference to the calling application.
1822 switch (pname)
1823 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001824 case GL_LINE_WIDTH:
1825 *params = mLineWidth;
1826 break;
1827 case GL_SAMPLE_COVERAGE_VALUE:
1828 *params = mSampleCoverageValue;
1829 break;
1830 case GL_DEPTH_CLEAR_VALUE:
1831 *params = mDepthClearValue;
1832 break;
1833 case GL_POLYGON_OFFSET_FACTOR:
1834 *params = mRasterizer.polygonOffsetFactor;
1835 break;
1836 case GL_POLYGON_OFFSET_UNITS:
1837 *params = mRasterizer.polygonOffsetUnits;
1838 break;
1839 case GL_DEPTH_RANGE:
1840 params[0] = mNearZ;
1841 params[1] = mFarZ;
1842 break;
1843 case GL_COLOR_CLEAR_VALUE:
1844 params[0] = mColorClearValue.red;
1845 params[1] = mColorClearValue.green;
1846 params[2] = mColorClearValue.blue;
1847 params[3] = mColorClearValue.alpha;
1848 break;
1849 case GL_BLEND_COLOR:
1850 params[0] = mBlendColor.red;
1851 params[1] = mBlendColor.green;
1852 params[2] = mBlendColor.blue;
1853 params[3] = mBlendColor.alpha;
1854 break;
1855 case GL_MULTISAMPLE_EXT:
1856 *params = static_cast<GLfloat>(mMultiSampling);
1857 break;
1858 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
1859 *params = static_cast<GLfloat>(mSampleAlphaToOne);
1860 break;
1861 case GL_COVERAGE_MODULATION_CHROMIUM:
1862 params[0] = static_cast<GLfloat>(mCoverageModulation);
1863 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -07001864 case GL_ALPHA_TEST_REF:
1865 *params = mGLES1State.mAlphaTestRef;
1866 break;
Lingfeng Yanga43994c2018-03-29 07:21:41 -07001867 case GL_CURRENT_COLOR:
1868 {
1869 const auto &color = mGLES1State.mCurrentColor;
1870 params[0] = color.red;
1871 params[1] = color.green;
1872 params[2] = color.blue;
1873 params[3] = color.alpha;
1874 break;
1875 }
Lingfeng Yang5a7e61b2018-03-29 16:50:32 -07001876 case GL_CURRENT_NORMAL:
1877 {
1878 const auto &normal = mGLES1State.mCurrentNormal;
1879 params[0] = normal[0];
1880 params[1] = normal[1];
1881 params[2] = normal[2];
1882 break;
1883 }
Lingfeng Yang038dd532018-03-29 17:31:52 -07001884 case GL_CURRENT_TEXTURE_COORDS:
1885 {
1886 const auto &texcoord = mGLES1State.mCurrentTextureCoords[mActiveSampler];
1887 params[0] = texcoord.s;
1888 params[1] = texcoord.t;
1889 params[2] = texcoord.r;
1890 params[3] = texcoord.q;
1891 break;
1892 }
Lingfeng Yang3a41af62018-04-09 07:28:56 -07001893 case GL_MODELVIEW_MATRIX:
1894 memcpy(params, mGLES1State.mModelviewMatrices.back().data(), 16 * sizeof(GLfloat));
1895 break;
1896 case GL_PROJECTION_MATRIX:
1897 memcpy(params, mGLES1State.mProjectionMatrices.back().data(), 16 * sizeof(GLfloat));
1898 break;
1899 case GL_TEXTURE_MATRIX:
1900 memcpy(params, mGLES1State.mTextureMatrices[mActiveSampler].back().data(),
1901 16 * sizeof(GLfloat));
1902 break;
Lingfeng Yangd0febe72018-05-17 22:36:52 -07001903 case GL_LIGHT_MODEL_AMBIENT:
1904 GetLightModelParameters(&mGLES1State, pname, params);
1905 break;
Lingfeng Yang7ba3f422018-06-01 09:43:04 -07001906 case GL_FOG_MODE:
1907 case GL_FOG_DENSITY:
1908 case GL_FOG_START:
1909 case GL_FOG_END:
1910 case GL_FOG_COLOR:
1911 GetFogParameters(&mGLES1State, pname, params);
1912 break;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -07001913 case GL_POINT_SIZE:
1914 GetPointSize(&mGLES1State, params);
1915 break;
1916 case GL_POINT_SIZE_MIN:
1917 case GL_POINT_SIZE_MAX:
1918 case GL_POINT_FADE_THRESHOLD_SIZE:
1919 case GL_POINT_DISTANCE_ATTENUATION:
1920 GetPointParameter(&mGLES1State, FromGLenum<PointParameter>(pname), params);
1921 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001922 default:
1923 UNREACHABLE();
1924 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04001925 }
1926}
1927
Jamie Madill526392d2018-11-16 09:35:14 -05001928angle::Result State::getIntegerv(const Context *context, GLenum pname, GLint *params)
Shannon Woods53a94a82014-06-24 15:20:36 -04001929{
1930 if (pname >= GL_DRAW_BUFFER0_EXT && pname <= GL_DRAW_BUFFER15_EXT)
1931 {
Geoff Lang3e922062018-11-15 11:26:29 -05001932 size_t drawBuffer = (pname - GL_DRAW_BUFFER0_EXT);
1933 ASSERT(drawBuffer < mMaxDrawBuffers);
Shannon Woods53a94a82014-06-24 15:20:36 -04001934 Framebuffer *framebuffer = mDrawFramebuffer;
Geoff Lang3e922062018-11-15 11:26:29 -05001935 // The default framebuffer may have fewer draw buffer states than a user-created one. The
1936 // user is always allowed to query up to GL_MAX_DRAWBUFFERS so just return GL_NONE here if
1937 // the draw buffer is out of range for this framebuffer.
1938 *params = drawBuffer < framebuffer->getDrawbufferStateCount()
1939 ? framebuffer->getDrawBufferState(drawBuffer)
1940 : GL_NONE;
Jamie Madill526392d2018-11-16 09:35:14 -05001941 return angle::Result::Continue();
Shannon Woods53a94a82014-06-24 15:20:36 -04001942 }
1943
1944 // Please note: DEPTH_CLEAR_VALUE is not included in our internal getIntegerv implementation
1945 // because it is stored as a float, despite the fact that the GL ES 2.0 spec names
1946 // GetIntegerv as its native query function. As it would require conversion in any
1947 // case, this should make no difference to the calling application. You may find it in
1948 // State::getFloatv.
1949 switch (pname)
1950 {
Corentin Wallez336129f2017-10-17 15:55:40 -04001951 case GL_ARRAY_BUFFER_BINDING:
1952 *params = mBoundBuffers[BufferBinding::Array].id();
1953 break;
1954 case GL_DRAW_INDIRECT_BUFFER_BINDING:
1955 *params = mBoundBuffers[BufferBinding::DrawIndirect].id();
1956 break;
1957 case GL_ELEMENT_ARRAY_BUFFER_BINDING:
Jamie Madillcd0a0a32018-10-18 18:41:57 -04001958 {
1959 Buffer *elementArrayBuffer = getVertexArray()->getElementArrayBuffer();
1960 *params = elementArrayBuffer ? elementArrayBuffer->id() : 0;
Corentin Wallez336129f2017-10-17 15:55:40 -04001961 break;
Jamie Madillcd0a0a32018-10-18 18:41:57 -04001962 }
Jamie Madill690c8eb2018-03-12 15:20:03 -04001963 case GL_DRAW_FRAMEBUFFER_BINDING:
1964 static_assert(GL_DRAW_FRAMEBUFFER_BINDING == GL_DRAW_FRAMEBUFFER_BINDING_ANGLE,
1965 "Enum mismatch");
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001966 *params = mDrawFramebuffer->id();
1967 break;
Jamie Madill690c8eb2018-03-12 15:20:03 -04001968 case GL_READ_FRAMEBUFFER_BINDING:
1969 static_assert(GL_READ_FRAMEBUFFER_BINDING == GL_READ_FRAMEBUFFER_BINDING_ANGLE,
1970 "Enum mismatch");
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001971 *params = mReadFramebuffer->id();
1972 break;
1973 case GL_RENDERBUFFER_BINDING:
1974 *params = mRenderbuffer.id();
1975 break;
1976 case GL_VERTEX_ARRAY_BINDING:
1977 *params = mVertexArray->id();
1978 break;
1979 case GL_CURRENT_PROGRAM:
1980 *params = mProgram ? mProgram->id() : 0;
1981 break;
1982 case GL_PACK_ALIGNMENT:
1983 *params = mPack.alignment;
1984 break;
1985 case GL_PACK_REVERSE_ROW_ORDER_ANGLE:
1986 *params = mPack.reverseRowOrder;
1987 break;
1988 case GL_PACK_ROW_LENGTH:
1989 *params = mPack.rowLength;
1990 break;
1991 case GL_PACK_SKIP_ROWS:
1992 *params = mPack.skipRows;
1993 break;
1994 case GL_PACK_SKIP_PIXELS:
1995 *params = mPack.skipPixels;
1996 break;
1997 case GL_UNPACK_ALIGNMENT:
1998 *params = mUnpack.alignment;
1999 break;
2000 case GL_UNPACK_ROW_LENGTH:
2001 *params = mUnpack.rowLength;
2002 break;
2003 case GL_UNPACK_IMAGE_HEIGHT:
2004 *params = mUnpack.imageHeight;
2005 break;
2006 case GL_UNPACK_SKIP_IMAGES:
2007 *params = mUnpack.skipImages;
2008 break;
2009 case GL_UNPACK_SKIP_ROWS:
2010 *params = mUnpack.skipRows;
2011 break;
2012 case GL_UNPACK_SKIP_PIXELS:
2013 *params = mUnpack.skipPixels;
2014 break;
2015 case GL_GENERATE_MIPMAP_HINT:
2016 *params = mGenerateMipmapHint;
2017 break;
2018 case GL_FRAGMENT_SHADER_DERIVATIVE_HINT_OES:
2019 *params = mFragmentShaderDerivativeHint;
2020 break;
2021 case GL_ACTIVE_TEXTURE:
2022 *params = (static_cast<GLint>(mActiveSampler) + GL_TEXTURE0);
2023 break;
2024 case GL_STENCIL_FUNC:
2025 *params = mDepthStencil.stencilFunc;
2026 break;
2027 case GL_STENCIL_REF:
2028 *params = mStencilRef;
2029 break;
2030 case GL_STENCIL_VALUE_MASK:
2031 *params = CastMaskValue(context, mDepthStencil.stencilMask);
2032 break;
2033 case GL_STENCIL_BACK_FUNC:
2034 *params = mDepthStencil.stencilBackFunc;
2035 break;
2036 case GL_STENCIL_BACK_REF:
2037 *params = mStencilBackRef;
2038 break;
2039 case GL_STENCIL_BACK_VALUE_MASK:
2040 *params = CastMaskValue(context, mDepthStencil.stencilBackMask);
2041 break;
2042 case GL_STENCIL_FAIL:
2043 *params = mDepthStencil.stencilFail;
2044 break;
2045 case GL_STENCIL_PASS_DEPTH_FAIL:
2046 *params = mDepthStencil.stencilPassDepthFail;
2047 break;
2048 case GL_STENCIL_PASS_DEPTH_PASS:
2049 *params = mDepthStencil.stencilPassDepthPass;
2050 break;
2051 case GL_STENCIL_BACK_FAIL:
2052 *params = mDepthStencil.stencilBackFail;
2053 break;
2054 case GL_STENCIL_BACK_PASS_DEPTH_FAIL:
2055 *params = mDepthStencil.stencilBackPassDepthFail;
2056 break;
2057 case GL_STENCIL_BACK_PASS_DEPTH_PASS:
2058 *params = mDepthStencil.stencilBackPassDepthPass;
2059 break;
2060 case GL_DEPTH_FUNC:
2061 *params = mDepthStencil.depthFunc;
2062 break;
2063 case GL_BLEND_SRC_RGB:
2064 *params = mBlend.sourceBlendRGB;
2065 break;
2066 case GL_BLEND_SRC_ALPHA:
2067 *params = mBlend.sourceBlendAlpha;
2068 break;
2069 case GL_BLEND_DST_RGB:
2070 *params = mBlend.destBlendRGB;
2071 break;
2072 case GL_BLEND_DST_ALPHA:
2073 *params = mBlend.destBlendAlpha;
2074 break;
2075 case GL_BLEND_EQUATION_RGB:
2076 *params = mBlend.blendEquationRGB;
2077 break;
2078 case GL_BLEND_EQUATION_ALPHA:
2079 *params = mBlend.blendEquationAlpha;
2080 break;
2081 case GL_STENCIL_WRITEMASK:
2082 *params = CastMaskValue(context, mDepthStencil.stencilWritemask);
2083 break;
2084 case GL_STENCIL_BACK_WRITEMASK:
2085 *params = CastMaskValue(context, mDepthStencil.stencilBackWritemask);
2086 break;
2087 case GL_STENCIL_CLEAR_VALUE:
2088 *params = mStencilClearValue;
2089 break;
2090 case GL_IMPLEMENTATION_COLOR_READ_TYPE:
Jamie Madill690c8eb2018-03-12 15:20:03 -04002091 ANGLE_TRY(mReadFramebuffer->getImplementationColorReadType(
2092 context, reinterpret_cast<GLenum *>(params)));
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002093 break;
2094 case GL_IMPLEMENTATION_COLOR_READ_FORMAT:
Jamie Madill690c8eb2018-03-12 15:20:03 -04002095 ANGLE_TRY(mReadFramebuffer->getImplementationColorReadFormat(
2096 context, reinterpret_cast<GLenum *>(params)));
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002097 break;
2098 case GL_SAMPLE_BUFFERS:
2099 case GL_SAMPLES:
Shannon Woods53a94a82014-06-24 15:20:36 -04002100 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002101 Framebuffer *framebuffer = mDrawFramebuffer;
Jamie Madill427064d2018-04-13 16:20:34 -04002102 if (framebuffer->isComplete(context))
Shannon Woods53a94a82014-06-24 15:20:36 -04002103 {
Jamie Madill427064d2018-04-13 16:20:34 -04002104 GLint samples = framebuffer->getSamples(context);
Shannon Woods53a94a82014-06-24 15:20:36 -04002105 switch (pname)
2106 {
Jamie Madilla0016b72017-07-14 14:30:46 -04002107 case GL_SAMPLE_BUFFERS:
Jamie Madille98b1b52018-03-08 09:47:23 -05002108 if (samples != 0)
Jamie Madilla0016b72017-07-14 14:30:46 -04002109 {
2110 *params = 1;
2111 }
2112 else
2113 {
2114 *params = 0;
2115 }
2116 break;
2117 case GL_SAMPLES:
Jamie Madille98b1b52018-03-08 09:47:23 -05002118 *params = samples;
Jamie Madilla0016b72017-07-14 14:30:46 -04002119 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002120 }
2121 }
2122 else
2123 {
2124 *params = 0;
2125 }
2126 }
2127 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002128 case GL_VIEWPORT:
2129 params[0] = mViewport.x;
2130 params[1] = mViewport.y;
2131 params[2] = mViewport.width;
2132 params[3] = mViewport.height;
2133 break;
2134 case GL_SCISSOR_BOX:
2135 params[0] = mScissor.x;
2136 params[1] = mScissor.y;
2137 params[2] = mScissor.width;
2138 params[3] = mScissor.height;
2139 break;
2140 case GL_CULL_FACE_MODE:
2141 *params = ToGLenum(mRasterizer.cullMode);
2142 break;
2143 case GL_FRONT_FACE:
2144 *params = mRasterizer.frontFace;
2145 break;
2146 case GL_RED_BITS:
2147 case GL_GREEN_BITS:
2148 case GL_BLUE_BITS:
2149 case GL_ALPHA_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002150 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002151 Framebuffer *framebuffer = getDrawFramebuffer();
2152 const FramebufferAttachment *colorbuffer = framebuffer->getFirstColorbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002153
2154 if (colorbuffer)
2155 {
2156 switch (pname)
2157 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002158 case GL_RED_BITS:
2159 *params = colorbuffer->getRedSize();
2160 break;
2161 case GL_GREEN_BITS:
2162 *params = colorbuffer->getGreenSize();
2163 break;
2164 case GL_BLUE_BITS:
2165 *params = colorbuffer->getBlueSize();
2166 break;
2167 case GL_ALPHA_BITS:
2168 *params = colorbuffer->getAlphaSize();
2169 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002170 }
2171 }
2172 else
2173 {
2174 *params = 0;
2175 }
2176 }
2177 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002178 case GL_DEPTH_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002179 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002180 const Framebuffer *framebuffer = getDrawFramebuffer();
2181 const FramebufferAttachment *depthbuffer = framebuffer->getDepthbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002182
2183 if (depthbuffer)
2184 {
2185 *params = depthbuffer->getDepthSize();
2186 }
2187 else
2188 {
2189 *params = 0;
2190 }
2191 }
2192 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002193 case GL_STENCIL_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002194 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002195 const Framebuffer *framebuffer = getDrawFramebuffer();
2196 const FramebufferAttachment *stencilbuffer = framebuffer->getStencilbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002197
2198 if (stencilbuffer)
2199 {
2200 *params = stencilbuffer->getStencilSize();
2201 }
2202 else
2203 {
2204 *params = 0;
2205 }
2206 }
2207 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002208 case GL_TEXTURE_BINDING_2D:
2209 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2210 *params =
2211 getSamplerTextureId(static_cast<unsigned int>(mActiveSampler), TextureType::_2D);
2212 break;
2213 case GL_TEXTURE_BINDING_RECTANGLE_ANGLE:
2214 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2215 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2216 TextureType::Rectangle);
2217 break;
2218 case GL_TEXTURE_BINDING_CUBE_MAP:
2219 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2220 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2221 TextureType::CubeMap);
2222 break;
2223 case GL_TEXTURE_BINDING_3D:
2224 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2225 *params =
2226 getSamplerTextureId(static_cast<unsigned int>(mActiveSampler), TextureType::_3D);
2227 break;
2228 case GL_TEXTURE_BINDING_2D_ARRAY:
2229 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2230 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2231 TextureType::_2DArray);
2232 break;
2233 case GL_TEXTURE_BINDING_2D_MULTISAMPLE:
2234 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2235 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2236 TextureType::_2DMultisample);
2237 break;
Olli Etuahodff32a02018-08-28 14:35:50 +03002238 case GL_TEXTURE_BINDING_2D_MULTISAMPLE_ARRAY:
2239 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2240 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2241 TextureType::_2DMultisampleArray);
2242 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002243 case GL_TEXTURE_BINDING_EXTERNAL_OES:
2244 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2245 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2246 TextureType::External);
2247 break;
2248 case GL_UNIFORM_BUFFER_BINDING:
2249 *params = mBoundBuffers[BufferBinding::Uniform].id();
2250 break;
2251 case GL_TRANSFORM_FEEDBACK_BINDING:
2252 *params = mTransformFeedback.id();
2253 break;
2254 case GL_TRANSFORM_FEEDBACK_BUFFER_BINDING:
2255 *params = mBoundBuffers[BufferBinding::TransformFeedback].id();
2256 break;
2257 case GL_COPY_READ_BUFFER_BINDING:
2258 *params = mBoundBuffers[BufferBinding::CopyRead].id();
2259 break;
2260 case GL_COPY_WRITE_BUFFER_BINDING:
2261 *params = mBoundBuffers[BufferBinding::CopyWrite].id();
2262 break;
2263 case GL_PIXEL_PACK_BUFFER_BINDING:
2264 *params = mBoundBuffers[BufferBinding::PixelPack].id();
2265 break;
2266 case GL_PIXEL_UNPACK_BUFFER_BINDING:
2267 *params = mBoundBuffers[BufferBinding::PixelUnpack].id();
2268 break;
2269 case GL_READ_BUFFER:
2270 *params = mReadFramebuffer->getReadBufferState();
2271 break;
2272 case GL_SAMPLER_BINDING:
2273 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2274 *params = getSamplerId(static_cast<GLuint>(mActiveSampler));
2275 break;
2276 case GL_DEBUG_LOGGED_MESSAGES:
2277 *params = static_cast<GLint>(mDebug.getMessageCount());
2278 break;
2279 case GL_DEBUG_NEXT_LOGGED_MESSAGE_LENGTH:
2280 *params = static_cast<GLint>(mDebug.getNextMessageLength());
2281 break;
2282 case GL_DEBUG_GROUP_STACK_DEPTH:
2283 *params = static_cast<GLint>(mDebug.getGroupStackDepth());
2284 break;
2285 case GL_MULTISAMPLE_EXT:
2286 *params = static_cast<GLint>(mMultiSampling);
2287 break;
2288 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
2289 *params = static_cast<GLint>(mSampleAlphaToOne);
2290 break;
2291 case GL_COVERAGE_MODULATION_CHROMIUM:
2292 *params = static_cast<GLint>(mCoverageModulation);
2293 break;
2294 case GL_ATOMIC_COUNTER_BUFFER_BINDING:
2295 *params = mBoundBuffers[BufferBinding::AtomicCounter].id();
2296 break;
2297 case GL_SHADER_STORAGE_BUFFER_BINDING:
2298 *params = mBoundBuffers[BufferBinding::ShaderStorage].id();
2299 break;
2300 case GL_DISPATCH_INDIRECT_BUFFER_BINDING:
2301 *params = mBoundBuffers[BufferBinding::DispatchIndirect].id();
2302 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -07002303 case GL_ALPHA_TEST_FUNC:
2304 *params = ToGLenum(mGLES1State.mAlphaTestFunc);
2305 break;
Lingfeng Yang96310cd2018-03-28 11:56:28 -07002306 case GL_CLIENT_ACTIVE_TEXTURE:
2307 *params = mGLES1State.mClientActiveTexture + GL_TEXTURE0;
2308 break;
Lingfeng Yangd2488ab2018-04-04 09:25:48 -07002309 case GL_MATRIX_MODE:
2310 *params = ToGLenum(mGLES1State.mMatrixMode);
2311 break;
Lingfeng Yanga0cfa872018-05-30 21:12:17 -07002312 case GL_SHADE_MODEL:
2313 *params = ToGLenum(mGLES1State.mShadeModel);
2314 break;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -07002315 case GL_MODELVIEW_STACK_DEPTH:
2316 case GL_PROJECTION_STACK_DEPTH:
2317 case GL_TEXTURE_STACK_DEPTH:
2318 *params = mGLES1State.getCurrentMatrixStackDepth(pname);
2319 break;
2320 case GL_LOGIC_OP_MODE:
2321 *params = ToGLenum(mGLES1State.mLogicOp);
2322 break;
2323 case GL_BLEND_SRC:
2324 *params = mBlend.sourceBlendRGB;
2325 break;
2326 case GL_BLEND_DST:
2327 *params = mBlend.destBlendRGB;
2328 break;
2329 case GL_PERSPECTIVE_CORRECTION_HINT:
2330 case GL_POINT_SMOOTH_HINT:
2331 case GL_LINE_SMOOTH_HINT:
2332 case GL_FOG_HINT:
2333 *params = mGLES1State.getHint(pname);
2334 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002335 default:
2336 UNREACHABLE();
2337 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002338 }
Jamie Madille98b1b52018-03-08 09:47:23 -05002339
Jamie Madill526392d2018-11-16 09:35:14 -05002340 return angle::Result::Continue();
Shannon Woods53a94a82014-06-24 15:20:36 -04002341}
2342
Lingfeng Yangabb09f12018-04-16 10:43:53 -07002343void State::getPointerv(const Context *context, GLenum pname, void **params) const
Geoff Lang70d0f492015-12-10 17:45:46 -05002344{
2345 switch (pname)
2346 {
2347 case GL_DEBUG_CALLBACK_FUNCTION:
2348 *params = reinterpret_cast<void *>(mDebug.getCallback());
2349 break;
2350 case GL_DEBUG_CALLBACK_USER_PARAM:
2351 *params = const_cast<void *>(mDebug.getUserParam());
2352 break;
Lingfeng Yangabb09f12018-04-16 10:43:53 -07002353 case GL_VERTEX_ARRAY_POINTER:
2354 case GL_NORMAL_ARRAY_POINTER:
2355 case GL_COLOR_ARRAY_POINTER:
2356 case GL_TEXTURE_COORD_ARRAY_POINTER:
2357 case GL_POINT_SIZE_ARRAY_POINTER_OES:
2358 QueryVertexAttribPointerv(getVertexArray()->getVertexAttribute(
2359 context->vertexArrayIndex(ParamToVertexArrayType(pname))),
2360 GL_VERTEX_ATTRIB_ARRAY_POINTER, params);
2361 return;
Geoff Lang70d0f492015-12-10 17:45:46 -05002362 default:
2363 UNREACHABLE();
2364 break;
2365 }
2366}
2367
Martin Radev66fb8202016-07-28 11:45:20 +03002368void State::getIntegeri_v(GLenum target, GLuint index, GLint *data)
Shannon Woods53a94a82014-06-24 15:20:36 -04002369{
2370 switch (target)
2371 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002372 case GL_TRANSFORM_FEEDBACK_BUFFER_BINDING:
2373 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2374 *data = mTransformFeedback->getIndexedBuffer(index).id();
2375 break;
2376 case GL_UNIFORM_BUFFER_BINDING:
2377 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2378 *data = mUniformBuffers[index].id();
2379 break;
2380 case GL_ATOMIC_COUNTER_BUFFER_BINDING:
2381 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2382 *data = mAtomicCounterBuffers[index].id();
2383 break;
2384 case GL_SHADER_STORAGE_BUFFER_BINDING:
2385 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2386 *data = mShaderStorageBuffers[index].id();
2387 break;
2388 case GL_VERTEX_BINDING_BUFFER:
2389 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2390 *data = mVertexArray->getVertexBinding(index).getBuffer().id();
2391 break;
2392 case GL_VERTEX_BINDING_DIVISOR:
2393 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2394 *data = mVertexArray->getVertexBinding(index).getDivisor();
2395 break;
2396 case GL_VERTEX_BINDING_OFFSET:
2397 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2398 *data = static_cast<GLuint>(mVertexArray->getVertexBinding(index).getOffset());
2399 break;
2400 case GL_VERTEX_BINDING_STRIDE:
2401 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2402 *data = mVertexArray->getVertexBinding(index).getStride();
2403 break;
2404 case GL_SAMPLE_MASK_VALUE:
2405 ASSERT(static_cast<size_t>(index) < mSampleMaskValues.size());
2406 *data = mSampleMaskValues[index];
2407 break;
2408 case GL_IMAGE_BINDING_NAME:
2409 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2410 *data = mImageUnits[index].texture.id();
2411 break;
2412 case GL_IMAGE_BINDING_LEVEL:
2413 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2414 *data = mImageUnits[index].level;
2415 break;
2416 case GL_IMAGE_BINDING_LAYER:
2417 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2418 *data = mImageUnits[index].layer;
2419 break;
2420 case GL_IMAGE_BINDING_ACCESS:
2421 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2422 *data = mImageUnits[index].access;
2423 break;
2424 case GL_IMAGE_BINDING_FORMAT:
2425 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2426 *data = mImageUnits[index].format;
2427 break;
2428 default:
2429 UNREACHABLE();
2430 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002431 }
Shannon Woods53a94a82014-06-24 15:20:36 -04002432}
2433
Martin Radev66fb8202016-07-28 11:45:20 +03002434void State::getInteger64i_v(GLenum target, GLuint index, GLint64 *data)
Shannon Woods53a94a82014-06-24 15:20:36 -04002435{
2436 switch (target)
2437 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002438 case GL_TRANSFORM_FEEDBACK_BUFFER_START:
2439 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2440 *data = mTransformFeedback->getIndexedBuffer(index).getOffset();
2441 break;
2442 case GL_TRANSFORM_FEEDBACK_BUFFER_SIZE:
2443 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2444 *data = mTransformFeedback->getIndexedBuffer(index).getSize();
2445 break;
2446 case GL_UNIFORM_BUFFER_START:
2447 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2448 *data = mUniformBuffers[index].getOffset();
2449 break;
2450 case GL_UNIFORM_BUFFER_SIZE:
2451 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2452 *data = mUniformBuffers[index].getSize();
2453 break;
2454 case GL_ATOMIC_COUNTER_BUFFER_START:
2455 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2456 *data = mAtomicCounterBuffers[index].getOffset();
2457 break;
2458 case GL_ATOMIC_COUNTER_BUFFER_SIZE:
2459 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2460 *data = mAtomicCounterBuffers[index].getSize();
2461 break;
2462 case GL_SHADER_STORAGE_BUFFER_START:
2463 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2464 *data = mShaderStorageBuffers[index].getOffset();
2465 break;
2466 case GL_SHADER_STORAGE_BUFFER_SIZE:
2467 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2468 *data = mShaderStorageBuffers[index].getSize();
2469 break;
2470 default:
2471 UNREACHABLE();
2472 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002473 }
Martin Radev66fb8202016-07-28 11:45:20 +03002474}
Shannon Woods53a94a82014-06-24 15:20:36 -04002475
Martin Radev66fb8202016-07-28 11:45:20 +03002476void State::getBooleani_v(GLenum target, GLuint index, GLboolean *data)
2477{
Xinghua Cao9c8e1a32017-12-06 17:59:58 +08002478 switch (target)
2479 {
2480 case GL_IMAGE_BINDING_LAYERED:
2481 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2482 *data = mImageUnits[index].layered;
2483 break;
2484 default:
2485 UNREACHABLE();
2486 break;
2487 }
Shannon Woods53a94a82014-06-24 15:20:36 -04002488}
2489
Markus Tavenrathf7f8c512018-11-18 15:56:45 +01002490angle::Result State::syncReadFramebuffer(const Context *context)
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002491{
Markus Tavenrathf7f8c512018-11-18 15:56:45 +01002492 ASSERT(mReadFramebuffer);
2493 return mReadFramebuffer->syncState(context);
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002494}
2495
Jamie Madillef9fcd92018-11-28 14:03:59 -05002496angle::Result State::syncDrawFramebuffer(const Context *context)
Markus Tavenrathf7f8c512018-11-18 15:56:45 +01002497{
2498 ASSERT(mDrawFramebuffer);
2499 return mDrawFramebuffer->syncState(context);
2500}
2501
Jamie Madillef9fcd92018-11-28 14:03:59 -05002502angle::Result State::syncDrawAttachments(const Context *context)
2503{
2504 ASSERT(mDrawFramebuffer);
2505 ASSERT(!mDrawFramebuffer->hasAnyDirtyBit());
2506 ASSERT(mRobustResourceInit);
2507 return mDrawFramebuffer->ensureDrawAttachmentsInitialized(context);
2508}
2509
Markus Tavenrathf7f8c512018-11-18 15:56:45 +01002510angle::Result State::syncVertexArray(const Context *context)
2511{
2512 ASSERT(mVertexArray);
2513 return mVertexArray->syncState(context);
2514}
2515
2516angle::Result State::syncProgram(const Context *context)
2517{
2518 return mProgram->syncState(context);
2519}
2520
2521angle::Result State::syncSamplers(const Context *context)
Jamie Madille25b8002018-09-20 13:39:49 -04002522{
2523 if (mDirtySamplers.none())
Markus Tavenrathf7f8c512018-11-18 15:56:45 +01002524 return angle::Result::Continue();
Jamie Madille25b8002018-09-20 13:39:49 -04002525
2526 // This could be optimized by tracking which samplers are dirty.
2527 for (size_t samplerIndex : mDirtySamplers)
2528 {
2529 BindingPointer<Sampler> &sampler = mSamplers[samplerIndex];
2530 if (sampler.get())
2531 {
2532 sampler->syncState(context);
2533 }
2534 }
2535
2536 mDirtySamplers.reset();
Markus Tavenrathf7f8c512018-11-18 15:56:45 +01002537
2538 return angle::Result::Continue();
Jamie Madille25b8002018-09-20 13:39:49 -04002539}
2540
Jamie Madill6f755b22018-10-09 12:48:54 -04002541angle::Result State::syncProgramTextures(const Context *context)
Jamie Madill81c2e252017-09-09 23:32:46 -04002542{
Jamie Madill81c2e252017-09-09 23:32:46 -04002543 // TODO(jmadill): Fine-grained updates.
2544 if (!mProgram)
2545 {
Jamie Madill6f755b22018-10-09 12:48:54 -04002546 return angle::Result::Continue();
Jamie Madill81c2e252017-09-09 23:32:46 -04002547 }
2548
2549 ASSERT(mDirtyObjects[DIRTY_OBJECT_PROGRAM_TEXTURES]);
2550 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
2551
Jamie Madill0f80ed82017-09-19 00:24:56 -04002552 ActiveTextureMask newActiveTextures;
2553
Geoff Lange51ba632017-11-21 11:45:25 -05002554 // Initialize to the 'Initialized' state and set to 'MayNeedInit' if any texture is not
2555 // initialized.
Yizhou Jiang7818a852018-09-06 15:02:04 +08002556 mCachedTexturesInitState = InitState::Initialized;
Qin Jiajia47f6dd02018-08-10 13:36:32 +08002557 mCachedImageTexturesInitState = InitState::Initialized;
Geoff Lange51ba632017-11-21 11:45:25 -05002558
Jamie Madill7e4eff12018-08-08 15:49:26 -04002559 const ActiveTextureMask &activeTextures = mProgram->getActiveSamplersMask();
2560 const ActiveTextureArray<TextureType> &textureTypes = mProgram->getActiveSamplerTypes();
2561
2562 for (size_t textureUnitIndex : activeTextures)
Jamie Madill81c2e252017-09-09 23:32:46 -04002563 {
Jamie Madill7e4eff12018-08-08 15:49:26 -04002564 TextureType textureType = textureTypes[textureUnitIndex];
Jamie Madill81c2e252017-09-09 23:32:46 -04002565
jchen1090f466a2018-08-13 15:05:25 +08002566 Texture *texture =
2567 getSamplerTexture(static_cast<unsigned int>(textureUnitIndex), textureType);
Jamie Madill7e4eff12018-08-08 15:49:26 -04002568 ASSERT(static_cast<size_t>(textureUnitIndex) < newActiveTextures.size());
2569
2570 ASSERT(texture);
2571
Jamie Madill7e4eff12018-08-08 15:49:26 -04002572 newActiveTextures.set(textureUnitIndex);
Jamie Madille3bb6b72018-10-03 17:51:15 -04002573 ANGLE_TRY(updateActiveTexture(context, textureUnitIndex, texture));
Jamie Madill81c2e252017-09-09 23:32:46 -04002574 }
Jamie Madill0f80ed82017-09-19 00:24:56 -04002575
2576 // Unset now missing textures.
Jamie Madill7e4eff12018-08-08 15:49:26 -04002577 ActiveTextureMask negativeMask = activeTextures & ~newActiveTextures;
Jamie Madill0f80ed82017-09-19 00:24:56 -04002578 if (negativeMask.any())
2579 {
Jamie Madille3bb6b72018-10-03 17:51:15 -04002580 unsetActiveTextures(negativeMask);
Jamie Madill0f80ed82017-09-19 00:24:56 -04002581 }
Luc Ferron4bba74f2018-04-19 14:40:45 -04002582
Qin Jiajia47f6dd02018-08-10 13:36:32 +08002583 for (size_t imageUnitIndex : mProgram->getActiveImagesMask())
2584 {
2585 Texture *texture = mImageUnits[imageUnitIndex].texture.get();
2586 if (!texture)
2587 {
2588 continue;
2589 }
Jamie Madillf668a4b2018-09-23 17:01:20 -04002590 if (texture->hasAnyDirtyBit())
2591 {
2592 ANGLE_TRY(texture->syncState(context));
2593 }
Qin Jiajia47f6dd02018-08-10 13:36:32 +08002594 if (texture->initState() == InitState::MayNeedInit)
2595 {
2596 mCachedImageTexturesInitState = InitState::MayNeedInit;
2597 }
2598 }
2599
Jamie Madill6f755b22018-10-09 12:48:54 -04002600 return angle::Result::Continue();
Jamie Madill81c2e252017-09-09 23:32:46 -04002601}
2602
Jamie Madill6f755b22018-10-09 12:48:54 -04002603angle::Result State::syncDirtyObject(const Context *context, GLenum target)
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002604{
2605 DirtyObjects localSet;
2606
2607 switch (target)
2608 {
2609 case GL_READ_FRAMEBUFFER:
2610 localSet.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2611 break;
2612 case GL_DRAW_FRAMEBUFFER:
2613 localSet.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2614 break;
2615 case GL_FRAMEBUFFER:
2616 localSet.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2617 localSet.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2618 break;
2619 case GL_VERTEX_ARRAY:
2620 localSet.set(DIRTY_OBJECT_VERTEX_ARRAY);
2621 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002622 case GL_TEXTURE:
Jamie Madille25b8002018-09-20 13:39:49 -04002623 localSet.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
2624 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002625 case GL_SAMPLER:
Jamie Madill70aeda42018-08-20 12:17:40 -04002626 localSet.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Jamie Madille25b8002018-09-20 13:39:49 -04002627 localSet.set(DIRTY_OBJECT_SAMPLERS);
Jamie Madill70aeda42018-08-20 12:17:40 -04002628 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002629 case GL_PROGRAM:
2630 localSet.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Jamie Madill70aeda42018-08-20 12:17:40 -04002631 localSet.set(DIRTY_OBJECT_PROGRAM);
Jamie Madill81c2e252017-09-09 23:32:46 -04002632 break;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002633 }
2634
Jamie Madillbc918e72018-03-08 09:47:21 -05002635 return syncDirtyObjects(context, localSet);
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002636}
2637
2638void State::setObjectDirty(GLenum target)
2639{
2640 switch (target)
2641 {
2642 case GL_READ_FRAMEBUFFER:
2643 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2644 break;
2645 case GL_DRAW_FRAMEBUFFER:
Jamie Madillef9fcd92018-11-28 14:03:59 -05002646 setDrawFramebufferDirty();
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002647 break;
2648 case GL_FRAMEBUFFER:
2649 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
Jamie Madillef9fcd92018-11-28 14:03:59 -05002650 setDrawFramebufferDirty();
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002651 break;
2652 case GL_VERTEX_ARRAY:
2653 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
2654 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002655 case GL_TEXTURE:
Jamie Madill70aeda42018-08-20 12:17:40 -04002656 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
2657 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
2658 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002659 case GL_PROGRAM:
2660 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Jamie Madill70aeda42018-08-20 12:17:40 -04002661 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM);
Jamie Madill81c2e252017-09-09 23:32:46 -04002662 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
2663 break;
Jamie Madilla779b612017-07-24 11:46:05 -04002664 }
2665}
2666
Jamie Madill6f755b22018-10-09 12:48:54 -04002667angle::Result State::onProgramExecutableChange(const Context *context, Program *program)
Jamie Madilla779b612017-07-24 11:46:05 -04002668{
2669 // OpenGL Spec:
2670 // "If LinkProgram or ProgramBinary successfully re-links a program object
2671 // that was already in use as a result of a previous call to UseProgram, then the
2672 // generated executable code will be installed as part of the current rendering state."
Jamie Madilldf836ff2018-10-01 10:36:24 -04002673 ASSERT(program->isLinked());
2674
2675 mDirtyBits.set(DIRTY_BIT_PROGRAM_EXECUTABLE);
Jamie Madill956ab4d2018-10-10 16:13:03 -04002676
2677 if (program->hasAnyDirtyBit())
2678 {
2679 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM);
2680 }
Jamie Madille3bb6b72018-10-03 17:51:15 -04002681
2682 // Set any bound textures.
2683 const ActiveTextureTypeArray &textureTypes = program->getActiveSamplerTypes();
2684 for (size_t textureIndex : program->getActiveSamplersMask())
2685 {
2686 TextureType type = textureTypes[textureIndex];
2687
2688 // This can happen if there is a conflicting texture type.
2689 if (type == TextureType::InvalidEnum)
2690 continue;
2691
2692 Texture *texture = mSamplerTextures[type][textureIndex].get();
2693 ANGLE_TRY(updateActiveTexture(context, textureIndex, texture));
2694 }
2695
2696 for (size_t imageUnitIndex : program->getActiveImagesMask())
2697 {
2698 Texture *image = mImageUnits[imageUnitIndex].texture.get();
2699 if (!image)
2700 continue;
2701
2702 if (image->hasAnyDirtyBit())
2703 {
2704 ANGLE_TRY(image->syncState(context));
2705 }
2706
2707 if (image->initState() == InitState::MayNeedInit)
2708 {
2709 mCachedImageTexturesInitState = InitState::MayNeedInit;
2710 }
2711 }
2712
Jamie Madill6f755b22018-10-09 12:48:54 -04002713 return angle::Result::Continue();
Shannon Woods53a94a82014-06-24 15:20:36 -04002714}
Jamie Madillc9d442d2016-01-20 11:17:24 -05002715
Jamie Madille25b8002018-09-20 13:39:49 -04002716void State::setSamplerDirty(size_t samplerIndex)
2717{
2718 mDirtyObjects.set(DIRTY_OBJECT_SAMPLERS);
2719 mDirtySamplers.set(samplerIndex);
2720}
2721
Xinghua Cao65ec0b22017-03-28 16:10:52 +08002722void State::setImageUnit(const Context *context,
Will Harris63aa0e52018-09-05 16:15:46 -07002723 size_t unit,
Xinghua Cao65ec0b22017-03-28 16:10:52 +08002724 Texture *texture,
2725 GLint level,
2726 GLboolean layered,
2727 GLint layer,
2728 GLenum access,
2729 GLenum format)
2730{
2731 mImageUnits[unit].texture.set(context, texture);
2732 mImageUnits[unit].level = level;
2733 mImageUnits[unit].layered = layered;
2734 mImageUnits[unit].layer = layer;
2735 mImageUnits[unit].access = access;
2736 mImageUnits[unit].format = format;
jchen1099118c12018-09-10 16:28:51 +08002737 mDirtyBits.set(DIRTY_BIT_IMAGE_BINDINGS);
Xinghua Cao65ec0b22017-03-28 16:10:52 +08002738}
2739
Jamie Madill81c2e252017-09-09 23:32:46 -04002740// Handle a dirty texture event.
Jamie Madill6c43a012018-08-08 15:49:27 -04002741void State::onActiveTextureStateChange(size_t textureIndex)
Jamie Madill81c2e252017-09-09 23:32:46 -04002742{
2743 // Conservatively assume all textures are dirty.
2744 // TODO(jmadill): More fine-grained update.
2745 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Geoff Lange51ba632017-11-21 11:45:25 -05002746
Jamie Madill6c43a012018-08-08 15:49:27 -04002747 if (!mActiveTexturesCache[textureIndex] ||
2748 mActiveTexturesCache[textureIndex]->initState() == InitState::MayNeedInit)
Geoff Lange51ba632017-11-21 11:45:25 -05002749 {
2750 mCachedTexturesInitState = InitState::MayNeedInit;
2751 }
Jamie Madill81c2e252017-09-09 23:32:46 -04002752}
2753
Jamie Madill6d32cef2018-08-14 02:34:28 -04002754void State::onUniformBufferStateChange(size_t uniformBufferIndex)
2755{
2756 // This could be represented by a different dirty bit. Using the same one keeps it simple.
2757 mDirtyBits.set(DIRTY_BIT_UNIFORM_BUFFER_BINDINGS);
2758}
2759
Jamie Madill6f755b22018-10-09 12:48:54 -04002760angle::Result State::clearUnclearedActiveTextures(const Context *context)
Jamie Madill05b35b22017-10-03 09:01:44 -04002761{
Jamie Madilla59fc192017-11-02 12:57:58 -04002762 ASSERT(mRobustResourceInit);
Geoff Lang9bf86f02018-07-26 11:46:34 -04002763 ASSERT(!mDirtyObjects[DIRTY_OBJECT_PROGRAM_TEXTURES]);
Geoff Langd4fff502017-09-22 11:28:28 -04002764
Jamie Madill7e4eff12018-08-08 15:49:26 -04002765 if (!mProgram)
Jamie Madill6f755b22018-10-09 12:48:54 -04002766 return angle::Result::Continue();
Jamie Madill7e4eff12018-08-08 15:49:26 -04002767
Qin Jiajia47f6dd02018-08-10 13:36:32 +08002768 if (mCachedTexturesInitState != InitState::Initialized)
Jamie Madill05b35b22017-10-03 09:01:44 -04002769 {
Qin Jiajia47f6dd02018-08-10 13:36:32 +08002770 for (size_t textureUnitIndex : mProgram->getActiveSamplersMask())
Jamie Madill05b35b22017-10-03 09:01:44 -04002771 {
Qin Jiajia47f6dd02018-08-10 13:36:32 +08002772 Texture *texture = mActiveTexturesCache[textureUnitIndex];
2773 if (texture)
2774 {
2775 ANGLE_TRY(texture->ensureInitialized(context));
2776 }
Jamie Madill05b35b22017-10-03 09:01:44 -04002777 }
Qin Jiajia47f6dd02018-08-10 13:36:32 +08002778 mCachedTexturesInitState = InitState::Initialized;
Jamie Madill05b35b22017-10-03 09:01:44 -04002779 }
Qin Jiajia47f6dd02018-08-10 13:36:32 +08002780 if (mCachedImageTexturesInitState != InitState::Initialized)
2781 {
2782 for (size_t imageUnitIndex : mProgram->getActiveImagesMask())
2783 {
2784 Texture *texture = mImageUnits[imageUnitIndex].texture.get();
2785 if (texture)
2786 {
2787 ANGLE_TRY(texture->ensureInitialized(context));
2788 }
2789 }
2790 mCachedImageTexturesInitState = InitState::Initialized;
2791 }
Jamie Madill6f755b22018-10-09 12:48:54 -04002792 return angle::Result::Continue();
Jamie Madill05b35b22017-10-03 09:01:44 -04002793}
2794
Jamie Madillc67323a2017-11-02 23:11:41 -04002795AttributesMask State::getAndResetDirtyCurrentValues() const
2796{
2797 AttributesMask retVal = mDirtyCurrentValues;
2798 mDirtyCurrentValues.reset();
2799 return retVal;
2800}
2801
Markus Tavenrathf7f8c512018-11-18 15:56:45 +01002802constexpr State::DirtyObjectHandler State::kDirtyObjectHandlers[DIRTY_OBJECT_MAX];
2803
Jamie Madillc9d442d2016-01-20 11:17:24 -05002804} // namespace gl