blob: ba5c9a39f649c7db27e45481fa1a3afe8781dcac [file] [log] [blame]
Shannon Woods53a94a82014-06-24 15:20:36 -04001//
2// Copyright (c) 2014 The ANGLE Project Authors. All rights reserved.
3// Use of this source code is governed by a BSD-style license that can be
4// found in the LICENSE file.
5//
6
7// State.cpp: Implements the State class, encapsulating raw GL state.
8
Geoff Lang2b5420c2014-11-19 14:20:15 -05009#include "libANGLE/State.h"
Shannon Woods53a94a82014-06-24 15:20:36 -040010
Sami Väisänene45e53b2016-05-25 10:36:04 +030011#include <string.h>
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -070012#include <limits>
Sami Väisänene45e53b2016-05-25 10:36:04 +030013
Jamie Madill20e005b2017-04-07 14:19:22 -040014#include "common/bitset_utils.h"
Sami Väisänene45e53b2016-05-25 10:36:04 +030015#include "common/mathutil.h"
jchen10a99ed552017-09-22 08:10:32 +080016#include "common/matrix_utils.h"
Geoff Lang2b5420c2014-11-19 14:20:15 -050017#include "libANGLE/Caps.h"
jchen10a99ed552017-09-22 08:10:32 +080018#include "libANGLE/Context.h"
Geoff Lang70d0f492015-12-10 17:45:46 -050019#include "libANGLE/Debug.h"
Geoff Lang2b5420c2014-11-19 14:20:15 -050020#include "libANGLE/Framebuffer.h"
21#include "libANGLE/FramebufferAttachment.h"
22#include "libANGLE/Query.h"
23#include "libANGLE/VertexArray.h"
24#include "libANGLE/formatutils.h"
jchen10a99ed552017-09-22 08:10:32 +080025#include "libANGLE/queryconversions.h"
Lingfeng Yangabb09f12018-04-16 10:43:53 -070026#include "libANGLE/queryutils.h"
Geoff Lang4751aab2017-10-30 15:14:52 -040027#include "libANGLE/renderer/ContextImpl.h"
Jamie Madillf668a4b2018-09-23 17:01:20 -040028#include "libANGLE/renderer/TextureImpl.h"
Shannon Woods53a94a82014-06-24 15:20:36 -040029
Corentin Wallezad3ae902018-03-09 13:40:42 -050030namespace gl
31{
32
Olli Etuahobbf1c102016-06-28 13:31:33 +030033namespace
34{
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
51} // anonymous namepace
52
Jamie Madillbf5177d2018-08-21 12:58:20 -040053template <typename BindingT, typename... ArgsT>
54void UpdateNonTFBufferBinding(const Context *context, BindingT *binding, ArgsT... args)
James Darpiniane8a93c62018-01-04 18:02:24 -080055{
56 if (binding->get())
Jamie Madillbf5177d2018-08-21 12:58:20 -040057 (*binding)->onNonTFBindingChanged(context, -1);
58 binding->set(context, args...);
James Darpiniane8a93c62018-01-04 18:02:24 -080059 if (binding->get())
Jamie Madillbf5177d2018-08-21 12:58:20 -040060 (*binding)->onNonTFBindingChanged(context, 1);
61}
62
63template <typename BindingT, typename... ArgsT>
64void UpdateTFBufferBinding(const Context *context, BindingT *binding, bool indexed, ArgsT... args)
65{
66 if (binding->get())
67 (*binding)->onTFBindingChanged(context, false, indexed);
68 binding->set(context, args...);
69 if (binding->get())
70 (*binding)->onTFBindingChanged(context, true, indexed);
James Darpiniane8a93c62018-01-04 18:02:24 -080071}
72
73void UpdateBufferBinding(const Context *context,
Jamie Madillbf5177d2018-08-21 12:58:20 -040074 BindingPointer<Buffer> *binding,
James Darpiniane8a93c62018-01-04 18:02:24 -080075 Buffer *buffer,
Jamie Madillbf5177d2018-08-21 12:58:20 -040076 BufferBinding target)
James Darpiniane8a93c62018-01-04 18:02:24 -080077{
Jamie Madillbf5177d2018-08-21 12:58:20 -040078 if (target == BufferBinding::TransformFeedback)
79 {
80 UpdateTFBufferBinding(context, binding, false, buffer);
81 }
82 else
83 {
84 UpdateNonTFBufferBinding(context, binding, buffer);
85 }
86}
87
88void UpdateIndexedBufferBinding(const Context *context,
89 OffsetBindingPointer<Buffer> *binding,
90 Buffer *buffer,
91 BufferBinding target,
92 GLintptr offset,
93 GLsizeiptr size)
94{
95 if (target == BufferBinding::TransformFeedback)
96 {
97 UpdateTFBufferBinding(context, binding, true, buffer, offset, size);
98 }
99 else
100 {
101 UpdateNonTFBufferBinding(context, binding, buffer, offset, size);
102 }
James Darpiniane8a93c62018-01-04 18:02:24 -0800103}
104
Geoff Lang4fb8a8b2018-06-01 16:47:57 -0400105State::State(bool debug,
106 bool bindGeneratesResource,
107 bool clientArraysEnabled,
108 bool robustResourceInit,
109 bool programBinaryCacheEnabled)
Jamie Madille79b1e12015-11-04 16:36:37 -0500110 : mMaxDrawBuffers(0),
111 mMaxCombinedTextureImageUnits(0),
112 mDepthClearValue(0),
113 mStencilClearValue(0),
114 mScissorTest(false),
115 mSampleCoverage(false),
116 mSampleCoverageValue(0),
117 mSampleCoverageInvert(false),
Jiawei Shaodb342272017-09-27 10:21:45 +0800118 mSampleMask(false),
119 mMaxSampleMaskWords(0),
Jamie Madille79b1e12015-11-04 16:36:37 -0500120 mStencilRef(0),
121 mStencilBackRef(0),
122 mLineWidth(0),
123 mGenerateMipmapHint(GL_NONE),
124 mFragmentShaderDerivativeHint(GL_NONE),
Geoff Lang4fb8a8b2018-06-01 16:47:57 -0400125 mBindGeneratesResource(bindGeneratesResource),
126 mClientArraysEnabled(clientArraysEnabled),
Jamie Madille79b1e12015-11-04 16:36:37 -0500127 mNearZ(0),
128 mFarZ(0),
129 mReadFramebuffer(nullptr),
130 mDrawFramebuffer(nullptr),
131 mProgram(nullptr),
132 mVertexArray(nullptr),
133 mActiveSampler(0),
Jamie Madill4787d702018-08-08 15:49:26 -0400134 mActiveTexturesCache{},
135 mCachedTexturesInitState(InitState::MayNeedInit),
Qin Jiajia47f6dd02018-08-10 13:36:32 +0800136 mCachedImageTexturesInitState(InitState::MayNeedInit),
Sami Väisänen74c23472016-05-09 17:30:30 +0300137 mPrimitiveRestart(false),
Geoff Lang4fb8a8b2018-06-01 16:47:57 -0400138 mDebug(debug),
Sami Väisänen74c23472016-05-09 17:30:30 +0300139 mMultiSampling(false),
Geoff Lang1d2c41d2016-10-19 16:14:46 -0700140 mSampleAlphaToOne(false),
Jamie Madille08a1d32017-03-07 17:24:06 -0500141 mFramebufferSRGB(true),
Geoff Lang4fb8a8b2018-06-01 16:47:57 -0400142 mRobustResourceInit(robustResourceInit),
jchen1082af6202018-06-22 10:59:52 +0800143 mProgramBinaryCacheEnabled(programBinaryCacheEnabled),
144 mMaxShaderCompilerThreads(std::numeric_limits<GLuint>::max())
Shannon Woods53a94a82014-06-24 15:20:36 -0400145{
Geoff Lang76b10c92014-09-05 16:28:14 -0400146}
147
Lingfeng Yang13b708f2018-03-21 12:14:10 -0700148State::~State()
149{
150}
Geoff Lang76b10c92014-09-05 16:28:14 -0400151
Jamie Madill6c43a012018-08-08 15:49:27 -0400152void State::initialize(Context *context)
Geoff Lang76b10c92014-09-05 16:28:14 -0400153{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700154 const Caps &caps = context->getCaps();
155 const Extensions &extensions = context->getExtensions();
Geoff Lang4751aab2017-10-30 15:14:52 -0400156 const Extensions &nativeExtensions = context->getImplementation()->getNativeExtensions();
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700157 const Version &clientVersion = context->getClientVersion();
Jamie Madill4928b7c2017-06-20 12:57:39 -0400158
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700159 mMaxDrawBuffers = caps.maxDrawBuffers;
Shannon Woods2df6a602014-09-26 16:12:07 -0400160 mMaxCombinedTextureImageUnits = caps.maxCombinedTextureImageUnits;
Shannon Woods53a94a82014-06-24 15:20:36 -0400161
Jamie Madillf75ab352015-03-16 10:46:52 -0400162 setColorClearValue(0.0f, 0.0f, 0.0f, 0.0f);
Shannon Woods53a94a82014-06-24 15:20:36 -0400163
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700164 mDepthClearValue = 1.0f;
Shannon Woods53a94a82014-06-24 15:20:36 -0400165 mStencilClearValue = 0;
166
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700167 mScissorTest = false;
168 mScissor.x = 0;
169 mScissor.y = 0;
170 mScissor.width = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400171 mScissor.height = 0;
172
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700173 mBlendColor.red = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400174 mBlendColor.green = 0;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700175 mBlendColor.blue = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400176 mBlendColor.alpha = 0;
177
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700178 mStencilRef = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400179 mStencilBackRef = 0;
180
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700181 mSampleCoverage = false;
182 mSampleCoverageValue = 1.0f;
Shannon Woods53a94a82014-06-24 15:20:36 -0400183 mSampleCoverageInvert = false;
Jiawei Shaodb342272017-09-27 10:21:45 +0800184
185 mMaxSampleMaskWords = caps.maxSampleMaskWords;
186 mSampleMask = false;
187 mSampleMaskValues.fill(~GLbitfield(0));
188
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700189 mGenerateMipmapHint = GL_DONT_CARE;
Shannon Woods53a94a82014-06-24 15:20:36 -0400190 mFragmentShaderDerivativeHint = GL_DONT_CARE;
191
192 mLineWidth = 1.0f;
193
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700194 mViewport.x = 0;
195 mViewport.y = 0;
196 mViewport.width = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400197 mViewport.height = 0;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700198 mNearZ = 0.0f;
199 mFarZ = 1.0f;
Shannon Woods53a94a82014-06-24 15:20:36 -0400200
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700201 mBlend.colorMaskRed = true;
Shannon Woods53a94a82014-06-24 15:20:36 -0400202 mBlend.colorMaskGreen = true;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700203 mBlend.colorMaskBlue = true;
Shannon Woods53a94a82014-06-24 15:20:36 -0400204 mBlend.colorMaskAlpha = true;
205
Geoff Lang76b10c92014-09-05 16:28:14 -0400206 mActiveSampler = 0;
207
Shannon Woods23e05002014-09-22 19:07:27 -0400208 mVertexAttribCurrentValues.resize(caps.maxVertexAttributes);
Shannon Woods53a94a82014-06-24 15:20:36 -0400209
Brandon Jonesc405ae72017-12-06 14:15:03 -0800210 // Set all indexes in state attributes type mask to float (default)
211 for (int i = 0; i < MAX_VERTEX_ATTRIBS; i++)
212 {
213 mCurrentValuesTypeMask.setIndex(GL_FLOAT, i);
214 }
215
Geoff Lang4dc3af02016-11-18 14:09:27 -0500216 mUniformBuffers.resize(caps.maxUniformBufferBindings);
Shannon Woodsf3acaf92014-09-23 18:07:11 -0400217
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800218 mSamplerTextures[TextureType::_2D].resize(caps.maxCombinedTextureImageUnits);
219 mSamplerTextures[TextureType::CubeMap].resize(caps.maxCombinedTextureImageUnits);
Geoff Langeb66a6e2016-10-31 13:06:12 -0400220 if (clientVersion >= Version(3, 0))
Shannon Woods53a94a82014-06-24 15:20:36 -0400221 {
Geoff Lang76b10c92014-09-05 16:28:14 -0400222 // TODO: These could also be enabled via extension
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800223 mSamplerTextures[TextureType::_2DArray].resize(caps.maxCombinedTextureImageUnits);
224 mSamplerTextures[TextureType::_3D].resize(caps.maxCombinedTextureImageUnits);
Shannon Woods53a94a82014-06-24 15:20:36 -0400225 }
Geoff Lang3b573612016-10-31 14:08:10 -0400226 if (clientVersion >= Version(3, 1))
227 {
Olli Etuahod310a432018-08-24 15:40:23 +0300228 // TODO(http://anglebug.com/2775): These could also be enabled via extension
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800229 mSamplerTextures[TextureType::_2DMultisample].resize(caps.maxCombinedTextureImageUnits);
Olli Etuahod310a432018-08-24 15:40:23 +0300230 mSamplerTextures[TextureType::_2DMultisampleArray].resize(
231 caps.maxCombinedTextureImageUnits);
Jiajia Qin6eafb042016-12-27 17:04:07 +0800232
233 mAtomicCounterBuffers.resize(caps.maxAtomicCounterBufferBindings);
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800234 mShaderStorageBuffers.resize(caps.maxShaderStorageBufferBindings);
Xinghua Cao65ec0b22017-03-28 16:10:52 +0800235 mImageUnits.resize(caps.maxImageUnits);
Geoff Lang3b573612016-10-31 14:08:10 -0400236 }
Geoff Lang4751aab2017-10-30 15:14:52 -0400237 if (nativeExtensions.textureRectangle)
Corentin Wallez13c0dd42017-07-04 18:27:01 -0400238 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800239 mSamplerTextures[TextureType::Rectangle].resize(caps.maxCombinedTextureImageUnits);
Corentin Wallez13c0dd42017-07-04 18:27:01 -0400240 }
Geoff Lang4751aab2017-10-30 15:14:52 -0400241 if (nativeExtensions.eglImageExternal || nativeExtensions.eglStreamConsumerExternal)
Ian Ewellbda75592016-04-18 17:25:54 -0400242 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800243 mSamplerTextures[TextureType::External].resize(caps.maxCombinedTextureImageUnits);
Ian Ewellbda75592016-04-18 17:25:54 -0400244 }
Jamie Madill81c2e252017-09-09 23:32:46 -0400245 mCompleteTextureBindings.reserve(caps.maxCombinedTextureImageUnits);
Geoff Lange51ba632017-11-21 11:45:25 -0500246 mCachedTexturesInitState = InitState::MayNeedInit;
Qin Jiajia47f6dd02018-08-10 13:36:32 +0800247 mCachedImageTexturesInitState = InitState::MayNeedInit;
Jamie Madill81c2e252017-09-09 23:32:46 -0400248 for (uint32_t textureIndex = 0; textureIndex < caps.maxCombinedTextureImageUnits;
249 ++textureIndex)
250 {
Jamie Madill6c43a012018-08-08 15:49:27 -0400251 mCompleteTextureBindings.emplace_back(context, textureIndex);
Jamie Madill81c2e252017-09-09 23:32:46 -0400252 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400253
Geoff Lang76b10c92014-09-05 16:28:14 -0400254 mSamplers.resize(caps.maxCombinedTextureImageUnits);
Shannon Woods53a94a82014-06-24 15:20:36 -0400255
Corentin Wallezad3ae902018-03-09 13:40:42 -0500256 for (QueryType type : angle::AllEnums<QueryType>())
257 {
258 mActiveQueries[type].set(context, nullptr);
259 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400260
Ian Ewell3ffd78b2016-01-22 16:09:42 -0500261 mProgram = nullptr;
Shannon Woods53a94a82014-06-24 15:20:36 -0400262
Ian Ewell3ffd78b2016-01-22 16:09:42 -0500263 mReadFramebuffer = nullptr;
264 mDrawFramebuffer = nullptr;
Jamie Madillb4b53c52015-02-03 15:22:48 -0500265
266 mPrimitiveRestart = false;
Geoff Lang70d0f492015-12-10 17:45:46 -0500267
Geoff Lang70d0f492015-12-10 17:45:46 -0500268 mDebug.setMaxLoggedMessages(extensions.maxDebugLoggedMessages);
Sami Väisänen74c23472016-05-09 17:30:30 +0300269
Geoff Lang488130e2017-09-27 13:53:11 -0400270 mMultiSampling = true;
271 mSampleAlphaToOne = false;
Sami Väisänena797e062016-05-12 15:23:40 +0300272
273 mCoverageModulation = GL_NONE;
Sami Väisänene45e53b2016-05-25 10:36:04 +0300274
275 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixProj);
276 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixMV);
277 mPathStencilFunc = GL_ALWAYS;
278 mPathStencilRef = 0;
279 mPathStencilMask = std::numeric_limits<GLuint>::max();
Jamie Madille08a1d32017-03-07 17:24:06 -0500280
Lingfeng Yangdbb9c532018-02-25 19:58:24 -0800281 // GLES1 emulation: Initialize state for GLES1 if version
282 // applies
283 if (clientVersion < Version(2, 0))
284 {
Lingfeng Yange547aac2018-04-05 09:39:20 -0700285 mGLES1State.initialize(context, this);
Lingfeng Yangdbb9c532018-02-25 19:58:24 -0800286 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400287}
288
Jamie Madill6c1f6712017-02-14 19:08:04 -0500289void State::reset(const Context *context)
Shannon Woods53a94a82014-06-24 15:20:36 -0400290{
Jamie Madill8693bdb2017-09-02 15:32:14 -0400291 for (auto &bindingVec : mSamplerTextures)
Shannon Woods53a94a82014-06-24 15:20:36 -0400292 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800293 for (size_t textureIdx = 0; textureIdx < bindingVec.size(); textureIdx++)
Shannon Woods53a94a82014-06-24 15:20:36 -0400294 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800295 bindingVec[textureIdx].set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400296 }
297 }
Geoff Lang76b10c92014-09-05 16:28:14 -0400298 for (size_t samplerIdx = 0; samplerIdx < mSamplers.size(); samplerIdx++)
299 {
Jamie Madill4928b7c2017-06-20 12:57:39 -0400300 mSamplers[samplerIdx].set(context, nullptr);
Geoff Lang76b10c92014-09-05 16:28:14 -0400301 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400302
Xinghua Cao65ec0b22017-03-28 16:10:52 +0800303 for (auto &imageUnit : mImageUnits)
304 {
305 imageUnit.texture.set(context, nullptr);
306 imageUnit.level = 0;
307 imageUnit.layered = false;
308 imageUnit.layer = 0;
309 imageUnit.access = GL_READ_ONLY;
310 imageUnit.format = GL_R32UI;
311 }
312
Jamie Madill4928b7c2017-06-20 12:57:39 -0400313 mRenderbuffer.set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400314
Corentin Wallez336129f2017-10-17 15:55:40 -0400315 for (auto type : angle::AllEnums<BufferBinding>())
316 {
Jamie Madillbf5177d2018-08-21 12:58:20 -0400317 UpdateBufferBinding(context, &mBoundBuffers[type], nullptr, type);
Corentin Wallez336129f2017-10-17 15:55:40 -0400318 }
319
Geoff Lang7dd2e102014-11-10 15:19:26 -0500320 if (mProgram)
321 {
Jamie Madill6c1f6712017-02-14 19:08:04 -0500322 mProgram->release(context);
Geoff Lang7dd2e102014-11-10 15:19:26 -0500323 }
Yunchao Hed7297bf2017-04-19 15:27:10 +0800324 mProgram = nullptr;
Geoff Lang7dd2e102014-11-10 15:19:26 -0500325
Yunchao Hea336b902017-08-02 16:05:21 +0800326 mProgramPipeline.set(context, nullptr);
327
James Darpiniane8a93c62018-01-04 18:02:24 -0800328 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -0400329 mTransformFeedback->onBindingChanged(context, false);
Jamie Madill4928b7c2017-06-20 12:57:39 -0400330 mTransformFeedback.set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400331
Corentin Wallezad3ae902018-03-09 13:40:42 -0500332 for (QueryType type : angle::AllEnums<QueryType>())
Shannon Woods53a94a82014-06-24 15:20:36 -0400333 {
Corentin Wallezad3ae902018-03-09 13:40:42 -0500334 mActiveQueries[type].set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400335 }
336
Corentin Wallez336129f2017-10-17 15:55:40 -0400337 for (auto &buf : mUniformBuffers)
Shannon Woods53a94a82014-06-24 15:20:36 -0400338 {
Jamie Madillbf5177d2018-08-21 12:58:20 -0400339 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::Uniform, 0, 0);
Shannon Woods53a94a82014-06-24 15:20:36 -0400340 }
341
Jiajia Qin6eafb042016-12-27 17:04:07 +0800342 for (auto &buf : mAtomicCounterBuffers)
343 {
Jamie Madillbf5177d2018-08-21 12:58:20 -0400344 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::AtomicCounter, 0, 0);
Jiajia Qin6eafb042016-12-27 17:04:07 +0800345 }
346
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800347 for (auto &buf : mShaderStorageBuffers)
348 {
Jamie Madillbf5177d2018-08-21 12:58:20 -0400349 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::ShaderStorage, 0, 0);
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800350 }
351
Sami Väisänene45e53b2016-05-25 10:36:04 +0300352 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixProj);
353 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixMV);
354 mPathStencilFunc = GL_ALWAYS;
355 mPathStencilRef = 0;
356 mPathStencilMask = std::numeric_limits<GLuint>::max();
357
Jamie Madill1b94d432015-08-07 13:23:23 -0400358 // TODO(jmadill): Is this necessary?
359 setAllDirtyBits();
Shannon Woods53a94a82014-06-24 15:20:36 -0400360}
361
362const RasterizerState &State::getRasterizerState() const
363{
364 return mRasterizer;
365}
366
367const BlendState &State::getBlendState() const
368{
369 return mBlend;
370}
371
372const DepthStencilState &State::getDepthStencilState() const
373{
374 return mDepthStencil;
375}
376
Jamie Madillf75ab352015-03-16 10:46:52 -0400377void State::setColorClearValue(float red, float green, float blue, float alpha)
Shannon Woods53a94a82014-06-24 15:20:36 -0400378{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700379 mColorClearValue.red = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400380 mColorClearValue.green = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700381 mColorClearValue.blue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400382 mColorClearValue.alpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400383 mDirtyBits.set(DIRTY_BIT_CLEAR_COLOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400384}
385
Jamie Madillf75ab352015-03-16 10:46:52 -0400386void State::setDepthClearValue(float depth)
Shannon Woods53a94a82014-06-24 15:20:36 -0400387{
388 mDepthClearValue = depth;
Jamie Madill1b94d432015-08-07 13:23:23 -0400389 mDirtyBits.set(DIRTY_BIT_CLEAR_DEPTH);
Shannon Woods53a94a82014-06-24 15:20:36 -0400390}
391
Jamie Madillf75ab352015-03-16 10:46:52 -0400392void State::setStencilClearValue(int stencil)
Shannon Woods53a94a82014-06-24 15:20:36 -0400393{
394 mStencilClearValue = stencil;
Jamie Madill1b94d432015-08-07 13:23:23 -0400395 mDirtyBits.set(DIRTY_BIT_CLEAR_STENCIL);
Shannon Woods53a94a82014-06-24 15:20:36 -0400396}
397
Shannon Woods53a94a82014-06-24 15:20:36 -0400398void State::setColorMask(bool red, bool green, bool blue, bool alpha)
399{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700400 mBlend.colorMaskRed = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400401 mBlend.colorMaskGreen = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700402 mBlend.colorMaskBlue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400403 mBlend.colorMaskAlpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400404 mDirtyBits.set(DIRTY_BIT_COLOR_MASK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400405}
406
407void State::setDepthMask(bool mask)
408{
409 mDepthStencil.depthMask = mask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400410 mDirtyBits.set(DIRTY_BIT_DEPTH_MASK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400411}
412
413bool State::isRasterizerDiscardEnabled() const
414{
415 return mRasterizer.rasterizerDiscard;
416}
417
418void State::setRasterizerDiscard(bool enabled)
419{
420 mRasterizer.rasterizerDiscard = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400421 mDirtyBits.set(DIRTY_BIT_RASTERIZER_DISCARD_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400422}
423
424bool State::isCullFaceEnabled() const
425{
426 return mRasterizer.cullFace;
427}
428
429void State::setCullFace(bool enabled)
430{
431 mRasterizer.cullFace = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400432 mDirtyBits.set(DIRTY_BIT_CULL_FACE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400433}
434
Corentin Wallez2e568cf2017-09-18 17:05:22 -0400435void State::setCullMode(CullFaceMode mode)
Shannon Woods53a94a82014-06-24 15:20:36 -0400436{
437 mRasterizer.cullMode = mode;
Jamie Madill1b94d432015-08-07 13:23:23 -0400438 mDirtyBits.set(DIRTY_BIT_CULL_FACE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400439}
440
441void State::setFrontFace(GLenum front)
442{
443 mRasterizer.frontFace = front;
Jamie Madill1b94d432015-08-07 13:23:23 -0400444 mDirtyBits.set(DIRTY_BIT_FRONT_FACE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400445}
446
447bool State::isDepthTestEnabled() const
448{
449 return mDepthStencil.depthTest;
450}
451
452void State::setDepthTest(bool enabled)
453{
454 mDepthStencil.depthTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400455 mDirtyBits.set(DIRTY_BIT_DEPTH_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400456}
457
458void State::setDepthFunc(GLenum depthFunc)
459{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700460 mDepthStencil.depthFunc = depthFunc;
461 mDirtyBits.set(DIRTY_BIT_DEPTH_FUNC);
Shannon Woods53a94a82014-06-24 15:20:36 -0400462}
463
464void State::setDepthRange(float zNear, float zFar)
465{
466 mNearZ = zNear;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700467 mFarZ = zFar;
Jamie Madill1b94d432015-08-07 13:23:23 -0400468 mDirtyBits.set(DIRTY_BIT_DEPTH_RANGE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400469}
470
Geoff Langd42f5b82015-04-16 14:03:29 -0400471float State::getNearPlane() const
Shannon Woods53a94a82014-06-24 15:20:36 -0400472{
Geoff Langd42f5b82015-04-16 14:03:29 -0400473 return mNearZ;
474}
475
476float State::getFarPlane() const
477{
478 return mFarZ;
Shannon Woods53a94a82014-06-24 15:20:36 -0400479}
480
481bool State::isBlendEnabled() const
482{
483 return mBlend.blend;
484}
485
486void State::setBlend(bool enabled)
487{
488 mBlend.blend = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400489 mDirtyBits.set(DIRTY_BIT_BLEND_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400490}
491
492void State::setBlendFactors(GLenum sourceRGB, GLenum destRGB, GLenum sourceAlpha, GLenum destAlpha)
493{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700494 mBlend.sourceBlendRGB = sourceRGB;
495 mBlend.destBlendRGB = destRGB;
Shannon Woods53a94a82014-06-24 15:20:36 -0400496 mBlend.sourceBlendAlpha = sourceAlpha;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700497 mBlend.destBlendAlpha = destAlpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400498 mDirtyBits.set(DIRTY_BIT_BLEND_FUNCS);
Shannon Woods53a94a82014-06-24 15:20:36 -0400499}
500
501void State::setBlendColor(float red, float green, float blue, float alpha)
502{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700503 mBlendColor.red = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400504 mBlendColor.green = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700505 mBlendColor.blue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400506 mBlendColor.alpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400507 mDirtyBits.set(DIRTY_BIT_BLEND_COLOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400508}
509
510void State::setBlendEquation(GLenum rgbEquation, GLenum alphaEquation)
511{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700512 mBlend.blendEquationRGB = rgbEquation;
Shannon Woods53a94a82014-06-24 15:20:36 -0400513 mBlend.blendEquationAlpha = alphaEquation;
Jamie Madill1b94d432015-08-07 13:23:23 -0400514 mDirtyBits.set(DIRTY_BIT_BLEND_EQUATIONS);
Shannon Woods53a94a82014-06-24 15:20:36 -0400515}
516
517const ColorF &State::getBlendColor() const
518{
519 return mBlendColor;
520}
521
522bool State::isStencilTestEnabled() const
523{
524 return mDepthStencil.stencilTest;
525}
526
527void State::setStencilTest(bool enabled)
528{
529 mDepthStencil.stencilTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400530 mDirtyBits.set(DIRTY_BIT_STENCIL_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400531}
532
533void State::setStencilParams(GLenum stencilFunc, GLint stencilRef, GLuint stencilMask)
534{
535 mDepthStencil.stencilFunc = stencilFunc;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700536 mStencilRef = (stencilRef > 0) ? stencilRef : 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400537 mDepthStencil.stencilMask = stencilMask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400538 mDirtyBits.set(DIRTY_BIT_STENCIL_FUNCS_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400539}
540
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700541void State::setStencilBackParams(GLenum stencilBackFunc,
542 GLint stencilBackRef,
543 GLuint stencilBackMask)
Shannon Woods53a94a82014-06-24 15:20:36 -0400544{
545 mDepthStencil.stencilBackFunc = stencilBackFunc;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700546 mStencilBackRef = (stencilBackRef > 0) ? stencilBackRef : 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400547 mDepthStencil.stencilBackMask = stencilBackMask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400548 mDirtyBits.set(DIRTY_BIT_STENCIL_FUNCS_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400549}
550
551void State::setStencilWritemask(GLuint stencilWritemask)
552{
553 mDepthStencil.stencilWritemask = stencilWritemask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400554 mDirtyBits.set(DIRTY_BIT_STENCIL_WRITEMASK_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400555}
556
557void State::setStencilBackWritemask(GLuint stencilBackWritemask)
558{
559 mDepthStencil.stencilBackWritemask = stencilBackWritemask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400560 mDirtyBits.set(DIRTY_BIT_STENCIL_WRITEMASK_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400561}
562
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700563void State::setStencilOperations(GLenum stencilFail,
564 GLenum stencilPassDepthFail,
565 GLenum stencilPassDepthPass)
Shannon Woods53a94a82014-06-24 15:20:36 -0400566{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700567 mDepthStencil.stencilFail = stencilFail;
Shannon Woods53a94a82014-06-24 15:20:36 -0400568 mDepthStencil.stencilPassDepthFail = stencilPassDepthFail;
569 mDepthStencil.stencilPassDepthPass = stencilPassDepthPass;
Jamie Madill1b94d432015-08-07 13:23:23 -0400570 mDirtyBits.set(DIRTY_BIT_STENCIL_OPS_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400571}
572
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700573void State::setStencilBackOperations(GLenum stencilBackFail,
574 GLenum stencilBackPassDepthFail,
575 GLenum stencilBackPassDepthPass)
Shannon Woods53a94a82014-06-24 15:20:36 -0400576{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700577 mDepthStencil.stencilBackFail = stencilBackFail;
Shannon Woods53a94a82014-06-24 15:20:36 -0400578 mDepthStencil.stencilBackPassDepthFail = stencilBackPassDepthFail;
579 mDepthStencil.stencilBackPassDepthPass = stencilBackPassDepthPass;
Jamie Madill1b94d432015-08-07 13:23:23 -0400580 mDirtyBits.set(DIRTY_BIT_STENCIL_OPS_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400581}
582
583GLint State::getStencilRef() const
584{
585 return mStencilRef;
586}
587
588GLint State::getStencilBackRef() const
589{
590 return mStencilBackRef;
591}
592
593bool State::isPolygonOffsetFillEnabled() const
594{
595 return mRasterizer.polygonOffsetFill;
596}
597
598void State::setPolygonOffsetFill(bool enabled)
599{
Jamie Madill1b94d432015-08-07 13:23:23 -0400600 mRasterizer.polygonOffsetFill = enabled;
601 mDirtyBits.set(DIRTY_BIT_POLYGON_OFFSET_FILL_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400602}
603
604void State::setPolygonOffsetParams(GLfloat factor, GLfloat units)
605{
606 // An application can pass NaN values here, so handle this gracefully
607 mRasterizer.polygonOffsetFactor = factor != factor ? 0.0f : factor;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700608 mRasterizer.polygonOffsetUnits = units != units ? 0.0f : units;
Jamie Madill1b94d432015-08-07 13:23:23 -0400609 mDirtyBits.set(DIRTY_BIT_POLYGON_OFFSET);
Shannon Woods53a94a82014-06-24 15:20:36 -0400610}
611
612bool State::isSampleAlphaToCoverageEnabled() const
613{
614 return mBlend.sampleAlphaToCoverage;
615}
616
617void State::setSampleAlphaToCoverage(bool enabled)
618{
619 mBlend.sampleAlphaToCoverage = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400620 mDirtyBits.set(DIRTY_BIT_SAMPLE_ALPHA_TO_COVERAGE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400621}
622
623bool State::isSampleCoverageEnabled() const
624{
625 return mSampleCoverage;
626}
627
628void State::setSampleCoverage(bool enabled)
629{
630 mSampleCoverage = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400631 mDirtyBits.set(DIRTY_BIT_SAMPLE_COVERAGE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400632}
633
634void State::setSampleCoverageParams(GLclampf value, bool invert)
635{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700636 mSampleCoverageValue = value;
Shannon Woods53a94a82014-06-24 15:20:36 -0400637 mSampleCoverageInvert = invert;
Jamie Madill1b94d432015-08-07 13:23:23 -0400638 mDirtyBits.set(DIRTY_BIT_SAMPLE_COVERAGE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400639}
640
Geoff Lang0fbb6002015-04-16 11:11:53 -0400641GLclampf State::getSampleCoverageValue() const
Shannon Woods53a94a82014-06-24 15:20:36 -0400642{
Geoff Lang0fbb6002015-04-16 11:11:53 -0400643 return mSampleCoverageValue;
644}
Shannon Woods53a94a82014-06-24 15:20:36 -0400645
Geoff Lang0fbb6002015-04-16 11:11:53 -0400646bool State::getSampleCoverageInvert() const
647{
648 return mSampleCoverageInvert;
Shannon Woods53a94a82014-06-24 15:20:36 -0400649}
650
Jiawei Shaodb342272017-09-27 10:21:45 +0800651bool State::isSampleMaskEnabled() const
652{
653 return mSampleMask;
654}
655
656void State::setSampleMaskEnabled(bool enabled)
657{
658 mSampleMask = enabled;
659 mDirtyBits.set(DIRTY_BIT_SAMPLE_MASK_ENABLED);
660}
661
662void State::setSampleMaskParams(GLuint maskNumber, GLbitfield mask)
663{
664 ASSERT(maskNumber < mMaxSampleMaskWords);
665 mSampleMaskValues[maskNumber] = mask;
Jamie Madillc67323a2017-11-02 23:11:41 -0400666 // TODO(jmadill): Use a child dirty bit if we ever use more than two words.
667 mDirtyBits.set(DIRTY_BIT_SAMPLE_MASK);
Jiawei Shaodb342272017-09-27 10:21:45 +0800668}
669
670GLbitfield State::getSampleMaskWord(GLuint maskNumber) const
671{
672 ASSERT(maskNumber < mMaxSampleMaskWords);
673 return mSampleMaskValues[maskNumber];
674}
675
676GLuint State::getMaxSampleMaskWords() const
677{
678 return mMaxSampleMaskWords;
679}
680
Sami Väisänen74c23472016-05-09 17:30:30 +0300681void State::setSampleAlphaToOne(bool enabled)
682{
683 mSampleAlphaToOne = enabled;
684 mDirtyBits.set(DIRTY_BIT_SAMPLE_ALPHA_TO_ONE);
685}
686
687bool State::isSampleAlphaToOneEnabled() const
688{
689 return mSampleAlphaToOne;
690}
691
692void State::setMultisampling(bool enabled)
693{
694 mMultiSampling = enabled;
695 mDirtyBits.set(DIRTY_BIT_MULTISAMPLING);
696}
697
698bool State::isMultisamplingEnabled() const
699{
700 return mMultiSampling;
701}
702
Shannon Woods53a94a82014-06-24 15:20:36 -0400703bool State::isScissorTestEnabled() const
704{
705 return mScissorTest;
706}
707
708void State::setScissorTest(bool enabled)
709{
710 mScissorTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400711 mDirtyBits.set(DIRTY_BIT_SCISSOR_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400712}
713
714void State::setScissorParams(GLint x, GLint y, GLsizei width, GLsizei height)
715{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700716 mScissor.x = x;
717 mScissor.y = y;
718 mScissor.width = width;
Shannon Woods53a94a82014-06-24 15:20:36 -0400719 mScissor.height = height;
Jamie Madill1b94d432015-08-07 13:23:23 -0400720 mDirtyBits.set(DIRTY_BIT_SCISSOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400721}
722
723const Rectangle &State::getScissor() const
724{
725 return mScissor;
726}
727
728bool State::isDitherEnabled() const
729{
730 return mBlend.dither;
731}
732
733void State::setDither(bool enabled)
734{
735 mBlend.dither = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400736 mDirtyBits.set(DIRTY_BIT_DITHER_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400737}
738
Jamie Madillb4b53c52015-02-03 15:22:48 -0500739bool State::isPrimitiveRestartEnabled() const
740{
741 return mPrimitiveRestart;
742}
743
744void State::setPrimitiveRestart(bool enabled)
745{
746 mPrimitiveRestart = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400747 mDirtyBits.set(DIRTY_BIT_PRIMITIVE_RESTART_ENABLED);
Jamie Madillb4b53c52015-02-03 15:22:48 -0500748}
749
Shannon Woods53a94a82014-06-24 15:20:36 -0400750void State::setEnableFeature(GLenum feature, bool enabled)
751{
752 switch (feature)
753 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700754 case GL_MULTISAMPLE_EXT:
755 setMultisampling(enabled);
756 break;
757 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
758 setSampleAlphaToOne(enabled);
759 break;
760 case GL_CULL_FACE:
761 setCullFace(enabled);
762 break;
763 case GL_POLYGON_OFFSET_FILL:
764 setPolygonOffsetFill(enabled);
765 break;
766 case GL_SAMPLE_ALPHA_TO_COVERAGE:
767 setSampleAlphaToCoverage(enabled);
768 break;
769 case GL_SAMPLE_COVERAGE:
770 setSampleCoverage(enabled);
771 break;
772 case GL_SCISSOR_TEST:
773 setScissorTest(enabled);
774 break;
775 case GL_STENCIL_TEST:
776 setStencilTest(enabled);
777 break;
778 case GL_DEPTH_TEST:
779 setDepthTest(enabled);
780 break;
781 case GL_BLEND:
782 setBlend(enabled);
783 break;
784 case GL_DITHER:
785 setDither(enabled);
786 break;
787 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
788 setPrimitiveRestart(enabled);
789 break;
790 case GL_RASTERIZER_DISCARD:
791 setRasterizerDiscard(enabled);
792 break;
793 case GL_SAMPLE_MASK:
794 setSampleMaskEnabled(enabled);
795 break;
796 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
797 mDebug.setOutputSynchronous(enabled);
798 break;
799 case GL_DEBUG_OUTPUT:
800 mDebug.setOutputEnabled(enabled);
801 break;
802 case GL_FRAMEBUFFER_SRGB_EXT:
803 setFramebufferSRGB(enabled);
804 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -0700805
806 // GLES1 emulation
807 case GL_ALPHA_TEST:
808 mGLES1State.mAlphaTestEnabled = enabled;
809 break;
Lingfeng Yang23dc90b2018-04-23 09:01:49 -0700810 case GL_TEXTURE_2D:
811 mGLES1State.mTexUnitEnables[mActiveSampler].set(TextureType::_2D, enabled);
812 break;
813 case GL_TEXTURE_CUBE_MAP:
814 mGLES1State.mTexUnitEnables[mActiveSampler].set(TextureType::CubeMap, enabled);
815 break;
Lingfeng Yangd0febe72018-05-17 22:36:52 -0700816 case GL_LIGHTING:
817 mGLES1State.mLightingEnabled = enabled;
818 break;
819 case GL_LIGHT0:
820 case GL_LIGHT1:
821 case GL_LIGHT2:
822 case GL_LIGHT3:
823 case GL_LIGHT4:
824 case GL_LIGHT5:
825 case GL_LIGHT6:
826 case GL_LIGHT7:
827 mGLES1State.mLights[feature - GL_LIGHT0].enabled = enabled;
828 break;
829 case GL_NORMALIZE:
830 mGLES1State.mNormalizeEnabled = enabled;
831 break;
832 case GL_RESCALE_NORMAL:
833 mGLES1State.mRescaleNormalEnabled = enabled;
834 break;
835 case GL_COLOR_MATERIAL:
836 mGLES1State.mColorMaterialEnabled = enabled;
837 break;
Lingfeng Yang060088a2018-05-30 20:40:57 -0700838 case GL_CLIP_PLANE0:
839 case GL_CLIP_PLANE1:
840 case GL_CLIP_PLANE2:
841 case GL_CLIP_PLANE3:
842 case GL_CLIP_PLANE4:
843 case GL_CLIP_PLANE5:
844 mGLES1State.mClipPlanes[feature - GL_CLIP_PLANE0].enabled = enabled;
845 break;
Lingfeng Yang7ba3f422018-06-01 09:43:04 -0700846 case GL_FOG:
847 mGLES1State.mFogEnabled = enabled;
848 break;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -0700849 case GL_POINT_SMOOTH:
850 mGLES1State.mPointSmoothEnabled = enabled;
851 break;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -0700852 case GL_LINE_SMOOTH:
853 mGLES1State.mLineSmoothEnabled = enabled;
854 break;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -0700855 case GL_POINT_SPRITE_OES:
856 mGLES1State.mPointSpriteEnabled = enabled;
857 break;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -0700858 case GL_COLOR_LOGIC_OP:
859 mGLES1State.mLogicOpEnabled = enabled;
860 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700861 default:
862 UNREACHABLE();
Shannon Woods53a94a82014-06-24 15:20:36 -0400863 }
864}
865
Jamie Madilldfde6ab2016-06-09 07:07:18 -0700866bool State::getEnableFeature(GLenum feature) const
Shannon Woods53a94a82014-06-24 15:20:36 -0400867{
868 switch (feature)
869 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700870 case GL_MULTISAMPLE_EXT:
871 return isMultisamplingEnabled();
872 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
873 return isSampleAlphaToOneEnabled();
874 case GL_CULL_FACE:
875 return isCullFaceEnabled();
876 case GL_POLYGON_OFFSET_FILL:
877 return isPolygonOffsetFillEnabled();
878 case GL_SAMPLE_ALPHA_TO_COVERAGE:
879 return isSampleAlphaToCoverageEnabled();
880 case GL_SAMPLE_COVERAGE:
881 return isSampleCoverageEnabled();
882 case GL_SCISSOR_TEST:
883 return isScissorTestEnabled();
884 case GL_STENCIL_TEST:
885 return isStencilTestEnabled();
886 case GL_DEPTH_TEST:
887 return isDepthTestEnabled();
888 case GL_BLEND:
889 return isBlendEnabled();
890 case GL_DITHER:
891 return isDitherEnabled();
892 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
893 return isPrimitiveRestartEnabled();
894 case GL_RASTERIZER_DISCARD:
895 return isRasterizerDiscardEnabled();
896 case GL_SAMPLE_MASK:
897 return isSampleMaskEnabled();
898 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
899 return mDebug.isOutputSynchronous();
900 case GL_DEBUG_OUTPUT:
901 return mDebug.isOutputEnabled();
902 case GL_BIND_GENERATES_RESOURCE_CHROMIUM:
903 return isBindGeneratesResourceEnabled();
904 case GL_CLIENT_ARRAYS_ANGLE:
905 return areClientArraysEnabled();
906 case GL_FRAMEBUFFER_SRGB_EXT:
907 return getFramebufferSRGB();
908 case GL_ROBUST_RESOURCE_INITIALIZATION_ANGLE:
909 return mRobustResourceInit;
910 case GL_PROGRAM_CACHE_ENABLED_ANGLE:
911 return mProgramBinaryCacheEnabled;
Jamie Madillc43be722017-07-13 16:22:14 -0400912
Lingfeng Yang13b708f2018-03-21 12:14:10 -0700913 // GLES1 emulation
914 case GL_ALPHA_TEST:
915 return mGLES1State.mAlphaTestEnabled;
Lingfeng Yang01074432018-04-16 10:19:51 -0700916 case GL_VERTEX_ARRAY:
917 return mGLES1State.mVertexArrayEnabled;
918 case GL_NORMAL_ARRAY:
919 return mGLES1State.mNormalArrayEnabled;
920 case GL_COLOR_ARRAY:
921 return mGLES1State.mColorArrayEnabled;
922 case GL_POINT_SIZE_ARRAY_OES:
923 return mGLES1State.mPointSizeArrayEnabled;
924 case GL_TEXTURE_COORD_ARRAY:
925 return mGLES1State.mTexCoordArrayEnabled[mGLES1State.mClientActiveTexture];
Lingfeng Yang23dc90b2018-04-23 09:01:49 -0700926 case GL_TEXTURE_2D:
927 return mGLES1State.mTexUnitEnables[mActiveSampler].test(TextureType::_2D);
928 case GL_TEXTURE_CUBE_MAP:
929 return mGLES1State.mTexUnitEnables[mActiveSampler].test(TextureType::CubeMap);
Lingfeng Yangd0febe72018-05-17 22:36:52 -0700930 case GL_LIGHTING:
931 return mGLES1State.mLightingEnabled;
932 case GL_LIGHT0:
933 case GL_LIGHT1:
934 case GL_LIGHT2:
935 case GL_LIGHT3:
936 case GL_LIGHT4:
937 case GL_LIGHT5:
938 case GL_LIGHT6:
939 case GL_LIGHT7:
940 return mGLES1State.mLights[feature - GL_LIGHT0].enabled;
941 case GL_NORMALIZE:
942 return mGLES1State.mNormalizeEnabled;
943 case GL_RESCALE_NORMAL:
944 return mGLES1State.mRescaleNormalEnabled;
945 case GL_COLOR_MATERIAL:
946 return mGLES1State.mColorMaterialEnabled;
Lingfeng Yang060088a2018-05-30 20:40:57 -0700947 case GL_CLIP_PLANE0:
948 case GL_CLIP_PLANE1:
949 case GL_CLIP_PLANE2:
950 case GL_CLIP_PLANE3:
951 case GL_CLIP_PLANE4:
952 case GL_CLIP_PLANE5:
953 return mGLES1State.mClipPlanes[feature - GL_CLIP_PLANE0].enabled;
Lingfeng Yang7ba3f422018-06-01 09:43:04 -0700954 case GL_FOG:
955 return mGLES1State.mFogEnabled;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -0700956 case GL_POINT_SMOOTH:
957 return mGLES1State.mPointSmoothEnabled;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -0700958 case GL_LINE_SMOOTH:
959 return mGLES1State.mLineSmoothEnabled;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -0700960 case GL_POINT_SPRITE_OES:
961 return mGLES1State.mPointSpriteEnabled;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -0700962 case GL_COLOR_LOGIC_OP:
963 return mGLES1State.mLogicOpEnabled;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700964 default:
965 UNREACHABLE();
966 return false;
Shannon Woods53a94a82014-06-24 15:20:36 -0400967 }
968}
969
970void State::setLineWidth(GLfloat width)
971{
972 mLineWidth = width;
Jamie Madill1b94d432015-08-07 13:23:23 -0400973 mDirtyBits.set(DIRTY_BIT_LINE_WIDTH);
Shannon Woods53a94a82014-06-24 15:20:36 -0400974}
975
Geoff Lang4b3f4162015-04-16 13:22:05 -0400976float State::getLineWidth() const
977{
978 return mLineWidth;
979}
980
Shannon Woods53a94a82014-06-24 15:20:36 -0400981void State::setGenerateMipmapHint(GLenum hint)
982{
983 mGenerateMipmapHint = hint;
Jamie Madill1b94d432015-08-07 13:23:23 -0400984 mDirtyBits.set(DIRTY_BIT_GENERATE_MIPMAP_HINT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400985}
986
987void State::setFragmentShaderDerivativeHint(GLenum hint)
988{
989 mFragmentShaderDerivativeHint = hint;
Jamie Madill1b94d432015-08-07 13:23:23 -0400990 mDirtyBits.set(DIRTY_BIT_SHADER_DERIVATIVE_HINT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400991 // TODO: Propagate the hint to shader translator so we can write
992 // ddx, ddx_coarse, or ddx_fine depending on the hint.
993 // Ignore for now. It is valid for implementations to ignore hint.
994}
995
Geoff Langfeb8c682017-02-13 16:07:35 -0500996bool State::areClientArraysEnabled() const
997{
998 return mClientArraysEnabled;
999}
1000
Shannon Woods53a94a82014-06-24 15:20:36 -04001001void State::setViewportParams(GLint x, GLint y, GLsizei width, GLsizei height)
1002{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001003 mViewport.x = x;
1004 mViewport.y = y;
1005 mViewport.width = width;
Shannon Woods53a94a82014-06-24 15:20:36 -04001006 mViewport.height = height;
Jamie Madill1b94d432015-08-07 13:23:23 -04001007 mDirtyBits.set(DIRTY_BIT_VIEWPORT);
Shannon Woods53a94a82014-06-24 15:20:36 -04001008}
1009
1010const Rectangle &State::getViewport() const
1011{
1012 return mViewport;
1013}
1014
1015void State::setActiveSampler(unsigned int active)
1016{
1017 mActiveSampler = active;
1018}
1019
1020unsigned int State::getActiveSampler() const
1021{
Cooper Partin4d61f7e2015-08-12 10:56:50 -07001022 return static_cast<unsigned int>(mActiveSampler);
Shannon Woods53a94a82014-06-24 15:20:36 -04001023}
1024
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001025void State::setSamplerTexture(const Context *context, TextureType type, Texture *texture)
Shannon Woods53a94a82014-06-24 15:20:36 -04001026{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001027 mSamplerTextures[type][mActiveSampler].set(context, texture);
Jamie Madill81c2e252017-09-09 23:32:46 -04001028 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
1029 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Shannon Woods53a94a82014-06-24 15:20:36 -04001030}
1031
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001032Texture *State::getTargetTexture(TextureType type) const
Jamie Madillc29968b2016-01-20 11:17:23 -05001033{
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001034 return getSamplerTexture(static_cast<unsigned int>(mActiveSampler), type);
Jamie Madillc29968b2016-01-20 11:17:23 -05001035}
1036
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001037GLuint State::getSamplerTextureId(unsigned int sampler, TextureType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001038{
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001039 ASSERT(sampler < mSamplerTextures[type].size());
1040 return mSamplerTextures[type][sampler].id();
Shannon Woods53a94a82014-06-24 15:20:36 -04001041}
1042
Jamie Madilla02315b2017-02-23 14:14:47 -05001043void State::detachTexture(const Context *context, const TextureMap &zeroTextures, GLuint texture)
Shannon Woods53a94a82014-06-24 15:20:36 -04001044{
1045 // Textures have a detach method on State rather than a simple
1046 // removeBinding, because the zero/null texture objects are managed
1047 // separately, and don't have to go through the Context's maps or
1048 // the ResourceManager.
1049
1050 // [OpenGL ES 2.0.24] section 3.8 page 84:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001051 // If a texture object is deleted, it is as if all texture units which are bound to that texture
1052 // object are rebound to texture object zero
Shannon Woods53a94a82014-06-24 15:20:36 -04001053
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001054 for (TextureType type : angle::AllEnums<TextureType>())
Shannon Woods53a94a82014-06-24 15:20:36 -04001055 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001056 TextureBindingVector &textureVector = mSamplerTextures[type];
Jamie Madill81c2e252017-09-09 23:32:46 -04001057 for (BindingPointer<Texture> &binding : textureVector)
Shannon Woods53a94a82014-06-24 15:20:36 -04001058 {
Geoff Lang76b10c92014-09-05 16:28:14 -04001059 if (binding.id() == texture)
Shannon Woods53a94a82014-06-24 15:20:36 -04001060 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001061 Texture *zeroTexture = zeroTextures[type].get();
1062 ASSERT(zeroTexture != nullptr);
Jamie Madille6382c32014-11-07 15:05:26 -05001063 // Zero textures are the "default" textures instead of NULL
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001064 binding.set(context, zeroTexture);
Jamie Madill81c2e252017-09-09 23:32:46 -04001065 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
Shannon Woods53a94a82014-06-24 15:20:36 -04001066 }
1067 }
1068 }
1069
Xinghua Cao65ec0b22017-03-28 16:10:52 +08001070 for (auto &bindingImageUnit : mImageUnits)
1071 {
1072 if (bindingImageUnit.texture.id() == texture)
1073 {
1074 bindingImageUnit.texture.set(context, nullptr);
1075 bindingImageUnit.level = 0;
1076 bindingImageUnit.layered = false;
1077 bindingImageUnit.layer = 0;
1078 bindingImageUnit.access = GL_READ_ONLY;
1079 bindingImageUnit.format = GL_R32UI;
1080 break;
1081 }
1082 }
1083
Shannon Woods53a94a82014-06-24 15:20:36 -04001084 // [OpenGL ES 2.0.24] section 4.4 page 112:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001085 // If a texture object is deleted while its image is attached to the currently bound
1086 // framebuffer, then it is as if Texture2DAttachment had been called, with a texture of 0, for
1087 // each attachment point to which this image was attached in the currently bound framebuffer.
Shannon Woods53a94a82014-06-24 15:20:36 -04001088
Jamie Madill8693bdb2017-09-02 15:32:14 -04001089 if (mReadFramebuffer && mReadFramebuffer->detachTexture(context, texture))
Shannon Woods53a94a82014-06-24 15:20:36 -04001090 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001091 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
Shannon Woods53a94a82014-06-24 15:20:36 -04001092 }
1093
Jamie Madill8693bdb2017-09-02 15:32:14 -04001094 if (mDrawFramebuffer && mDrawFramebuffer->detachTexture(context, texture))
Shannon Woods53a94a82014-06-24 15:20:36 -04001095 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001096 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
Shannon Woods53a94a82014-06-24 15:20:36 -04001097 }
1098}
1099
Jamie Madill4928b7c2017-06-20 12:57:39 -04001100void State::initializeZeroTextures(const Context *context, const TextureMap &zeroTextures)
Jamie Madille6382c32014-11-07 15:05:26 -05001101{
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001102 for (TextureType type : angle::AllEnums<TextureType>())
Jamie Madille6382c32014-11-07 15:05:26 -05001103 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001104 for (size_t textureUnit = 0; textureUnit < mSamplerTextures[type].size(); ++textureUnit)
Jamie Madille6382c32014-11-07 15:05:26 -05001105 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001106 mSamplerTextures[type][textureUnit].set(context, zeroTextures[type].get());
Jamie Madille6382c32014-11-07 15:05:26 -05001107 }
1108 }
1109}
1110
Jamie Madill4928b7c2017-06-20 12:57:39 -04001111void State::setSamplerBinding(const Context *context, GLuint textureUnit, Sampler *sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001112{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001113 mSamplers[textureUnit].set(context, sampler);
Jamie Madill81c2e252017-09-09 23:32:46 -04001114 mDirtyBits.set(DIRTY_BIT_SAMPLER_BINDINGS);
1115 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Jamie Madille25b8002018-09-20 13:39:49 -04001116 // This is overly conservative as it assumes the sampler has never been bound.
1117 setSamplerDirty(textureUnit);
Shannon Woods53a94a82014-06-24 15:20:36 -04001118}
1119
1120GLuint State::getSamplerId(GLuint textureUnit) const
1121{
Geoff Lang76b10c92014-09-05 16:28:14 -04001122 ASSERT(textureUnit < mSamplers.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001123 return mSamplers[textureUnit].id();
1124}
1125
Jamie Madill4928b7c2017-06-20 12:57:39 -04001126void State::detachSampler(const Context *context, GLuint sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001127{
1128 // [OpenGL ES 3.0.2] section 3.8.2 pages 123-124:
1129 // If a sampler object that is currently bound to one or more texture units is
1130 // deleted, it is as though BindSampler is called once for each texture unit to
1131 // which the sampler is bound, with unit set to the texture unit and sampler set to zero.
Jamie Madill81c2e252017-09-09 23:32:46 -04001132 for (BindingPointer<Sampler> &samplerBinding : mSamplers)
Shannon Woods53a94a82014-06-24 15:20:36 -04001133 {
Geoff Lang76b10c92014-09-05 16:28:14 -04001134 if (samplerBinding.id() == sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001135 {
Jamie Madill4928b7c2017-06-20 12:57:39 -04001136 samplerBinding.set(context, nullptr);
Jamie Madill81c2e252017-09-09 23:32:46 -04001137 mDirtyBits.set(DIRTY_BIT_SAMPLER_BINDINGS);
Shannon Woods53a94a82014-06-24 15:20:36 -04001138 }
1139 }
1140}
1141
Jamie Madill4928b7c2017-06-20 12:57:39 -04001142void State::setRenderbufferBinding(const Context *context, Renderbuffer *renderbuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001143{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001144 mRenderbuffer.set(context, renderbuffer);
Jamie Madill8693bdb2017-09-02 15:32:14 -04001145 mDirtyBits.set(DIRTY_BIT_RENDERBUFFER_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001146}
1147
1148GLuint State::getRenderbufferId() const
1149{
1150 return mRenderbuffer.id();
1151}
1152
Jamie Madilldfde6ab2016-06-09 07:07:18 -07001153Renderbuffer *State::getCurrentRenderbuffer() const
Shannon Woods53a94a82014-06-24 15:20:36 -04001154{
1155 return mRenderbuffer.get();
1156}
1157
Jamie Madilla02315b2017-02-23 14:14:47 -05001158void State::detachRenderbuffer(const Context *context, GLuint renderbuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001159{
1160 // [OpenGL ES 2.0.24] section 4.4 page 109:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001161 // If a renderbuffer that is currently bound to RENDERBUFFER is deleted, it is as though
1162 // BindRenderbuffer had been executed with the target RENDERBUFFER and name of zero.
Shannon Woods53a94a82014-06-24 15:20:36 -04001163
1164 if (mRenderbuffer.id() == renderbuffer)
1165 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001166 setRenderbufferBinding(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001167 }
1168
1169 // [OpenGL ES 2.0.24] section 4.4 page 111:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001170 // If a renderbuffer object is deleted while its image is attached to the currently bound
1171 // framebuffer, then it is as if FramebufferRenderbuffer had been called, with a renderbuffer of
1172 // 0, for each attachment point to which this image was attached in the currently bound
1173 // framebuffer.
Shannon Woods53a94a82014-06-24 15:20:36 -04001174
1175 Framebuffer *readFramebuffer = mReadFramebuffer;
1176 Framebuffer *drawFramebuffer = mDrawFramebuffer;
1177
Jamie Madill8693bdb2017-09-02 15:32:14 -04001178 if (readFramebuffer && readFramebuffer->detachRenderbuffer(context, renderbuffer))
Shannon Woods53a94a82014-06-24 15:20:36 -04001179 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001180 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
Shannon Woods53a94a82014-06-24 15:20:36 -04001181 }
1182
1183 if (drawFramebuffer && drawFramebuffer != readFramebuffer)
1184 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001185 if (drawFramebuffer->detachRenderbuffer(context, renderbuffer))
1186 {
1187 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
1188 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001189 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001190}
1191
1192void State::setReadFramebufferBinding(Framebuffer *framebuffer)
1193{
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001194 if (mReadFramebuffer == framebuffer)
1195 return;
1196
Shannon Woods53a94a82014-06-24 15:20:36 -04001197 mReadFramebuffer = framebuffer;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001198 mDirtyBits.set(DIRTY_BIT_READ_FRAMEBUFFER_BINDING);
1199
1200 if (mReadFramebuffer && mReadFramebuffer->hasAnyDirtyBit())
1201 {
1202 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
1203 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001204}
1205
1206void State::setDrawFramebufferBinding(Framebuffer *framebuffer)
1207{
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001208 if (mDrawFramebuffer == framebuffer)
1209 return;
1210
Shannon Woods53a94a82014-06-24 15:20:36 -04001211 mDrawFramebuffer = framebuffer;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001212 mDirtyBits.set(DIRTY_BIT_DRAW_FRAMEBUFFER_BINDING);
1213
1214 if (mDrawFramebuffer && mDrawFramebuffer->hasAnyDirtyBit())
1215 {
1216 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
1217 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001218}
1219
1220Framebuffer *State::getTargetFramebuffer(GLenum target) const
1221{
1222 switch (target)
1223 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001224 case GL_READ_FRAMEBUFFER_ANGLE:
1225 return mReadFramebuffer;
1226 case GL_DRAW_FRAMEBUFFER_ANGLE:
1227 case GL_FRAMEBUFFER:
1228 return mDrawFramebuffer;
1229 default:
1230 UNREACHABLE();
Yunchao Hef81ce4a2017-04-24 10:49:17 +08001231 return nullptr;
Shannon Woods53a94a82014-06-24 15:20:36 -04001232 }
1233}
1234
Jamie Madill51f40ec2016-06-15 14:06:00 -04001235Framebuffer *State::getReadFramebuffer() const
Shannon Woods53a94a82014-06-24 15:20:36 -04001236{
1237 return mReadFramebuffer;
1238}
1239
Shannon Woods53a94a82014-06-24 15:20:36 -04001240bool State::removeReadFramebufferBinding(GLuint framebuffer)
1241{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001242 if (mReadFramebuffer != nullptr && mReadFramebuffer->id() == framebuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001243 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001244 setReadFramebufferBinding(nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001245 return true;
1246 }
1247
1248 return false;
1249}
1250
1251bool State::removeDrawFramebufferBinding(GLuint framebuffer)
1252{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001253 if (mReadFramebuffer != nullptr && mDrawFramebuffer->id() == framebuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001254 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001255 setDrawFramebufferBinding(nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001256 return true;
1257 }
1258
1259 return false;
1260}
1261
Jamie Madill7267aa62018-04-17 15:28:21 -04001262void State::setVertexArrayBinding(const Context *context, VertexArray *vertexArray)
Shannon Woods53a94a82014-06-24 15:20:36 -04001263{
James Darpiniane8a93c62018-01-04 18:02:24 -08001264 if (mVertexArray == vertexArray)
1265 return;
1266 if (mVertexArray)
Jamie Madillbf5177d2018-08-21 12:58:20 -04001267 mVertexArray->onBindingChanged(context, -1);
Shannon Woods53a94a82014-06-24 15:20:36 -04001268 mVertexArray = vertexArray;
James Darpiniane8a93c62018-01-04 18:02:24 -08001269 if (vertexArray)
Jamie Madillbf5177d2018-08-21 12:58:20 -04001270 vertexArray->onBindingChanged(context, 1);
Jamie Madill0b9e9032015-08-17 11:51:52 +00001271 mDirtyBits.set(DIRTY_BIT_VERTEX_ARRAY_BINDING);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001272
1273 if (mVertexArray && mVertexArray->hasAnyDirtyBit())
1274 {
1275 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1276 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001277}
1278
1279GLuint State::getVertexArrayId() const
1280{
Yunchao He4f285442017-04-21 12:15:49 +08001281 ASSERT(mVertexArray != nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001282 return mVertexArray->id();
1283}
1284
Jamie Madill7267aa62018-04-17 15:28:21 -04001285bool State::removeVertexArrayBinding(const Context *context, GLuint vertexArray)
Shannon Woods53a94a82014-06-24 15:20:36 -04001286{
James Darpiniane8a93c62018-01-04 18:02:24 -08001287 if (mVertexArray && mVertexArray->id() == vertexArray)
Shannon Woods53a94a82014-06-24 15:20:36 -04001288 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001289 mVertexArray->onBindingChanged(context, -1);
Yunchao Hed7297bf2017-04-19 15:27:10 +08001290 mVertexArray = nullptr;
Jamie Madill0b9e9032015-08-17 11:51:52 +00001291 mDirtyBits.set(DIRTY_BIT_VERTEX_ARRAY_BINDING);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001292 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001293 return true;
1294 }
1295
1296 return false;
1297}
1298
Jamie Madill4928b7c2017-06-20 12:57:39 -04001299void State::bindVertexBuffer(const Context *context,
1300 GLuint bindingIndex,
Shao80957d92017-02-20 21:25:59 +08001301 Buffer *boundBuffer,
1302 GLintptr offset,
1303 GLsizei stride)
1304{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001305 getVertexArray()->bindVertexBuffer(context, bindingIndex, boundBuffer, offset, stride);
Shao80957d92017-02-20 21:25:59 +08001306 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1307}
1308
Shaodde78e82017-05-22 14:13:27 +08001309void State::setVertexAttribBinding(const Context *context, GLuint attribIndex, GLuint bindingIndex)
Shao80957d92017-02-20 21:25:59 +08001310{
Shaodde78e82017-05-22 14:13:27 +08001311 getVertexArray()->setVertexAttribBinding(context, attribIndex, bindingIndex);
Shao80957d92017-02-20 21:25:59 +08001312 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1313}
1314
1315void State::setVertexAttribFormat(GLuint attribIndex,
1316 GLint size,
1317 GLenum type,
1318 bool normalized,
1319 bool pureInteger,
1320 GLuint relativeOffset)
1321{
1322 getVertexArray()->setVertexAttribFormat(attribIndex, size, type, normalized, pureInteger,
1323 relativeOffset);
1324 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1325}
1326
1327void State::setVertexBindingDivisor(GLuint bindingIndex, GLuint divisor)
1328{
1329 getVertexArray()->setVertexBindingDivisor(bindingIndex, divisor);
1330 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1331}
1332
Jamie Madill6c1f6712017-02-14 19:08:04 -05001333void State::setProgram(const Context *context, Program *newProgram)
Shannon Woods53a94a82014-06-24 15:20:36 -04001334{
Geoff Lang7dd2e102014-11-10 15:19:26 -05001335 if (mProgram != newProgram)
Shannon Woods53a94a82014-06-24 15:20:36 -04001336 {
Geoff Lang7dd2e102014-11-10 15:19:26 -05001337 if (mProgram)
1338 {
Jamie Madill6c1f6712017-02-14 19:08:04 -05001339 mProgram->release(context);
Geoff Lang7dd2e102014-11-10 15:19:26 -05001340 }
1341
1342 mProgram = newProgram;
1343
1344 if (mProgram)
1345 {
1346 newProgram->addRef();
Jamie Madill81c2e252017-09-09 23:32:46 -04001347 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Geoff Lang7dd2e102014-11-10 15:19:26 -05001348 }
Jamie Madilla779b612017-07-24 11:46:05 -04001349 mDirtyBits.set(DIRTY_BIT_PROGRAM_EXECUTABLE);
1350 mDirtyBits.set(DIRTY_BIT_PROGRAM_BINDING);
Jamie Madill70aeda42018-08-20 12:17:40 -04001351 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM);
Shannon Woods53a94a82014-06-24 15:20:36 -04001352 }
1353}
1354
Jamie Madill4928b7c2017-06-20 12:57:39 -04001355void State::setTransformFeedbackBinding(const Context *context,
1356 TransformFeedback *transformFeedback)
Shannon Woods53a94a82014-06-24 15:20:36 -04001357{
James Darpiniane8a93c62018-01-04 18:02:24 -08001358 if (transformFeedback == mTransformFeedback.get())
1359 return;
1360 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -04001361 mTransformFeedback->onBindingChanged(context, false);
Jamie Madill4928b7c2017-06-20 12:57:39 -04001362 mTransformFeedback.set(context, transformFeedback);
James Darpiniane8a93c62018-01-04 18:02:24 -08001363 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -04001364 mTransformFeedback->onBindingChanged(context, true);
Geoff Langded79232017-11-28 15:21:11 -05001365 mDirtyBits.set(DIRTY_BIT_TRANSFORM_FEEDBACK_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001366}
1367
Gregoire Payen de La Garanderie52742022015-02-04 14:55:39 +00001368bool State::isTransformFeedbackActiveUnpaused() const
1369{
Jamie Madill4166f012018-05-31 14:53:30 -04001370 TransformFeedback *curTransformFeedback = mTransformFeedback.get();
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001371 return curTransformFeedback && curTransformFeedback->isActive() &&
1372 !curTransformFeedback->isPaused();
Gregoire Payen de La Garanderie52742022015-02-04 14:55:39 +00001373}
1374
Jamie Madill4928b7c2017-06-20 12:57:39 -04001375bool State::removeTransformFeedbackBinding(const Context *context, GLuint transformFeedback)
Shannon Woods53a94a82014-06-24 15:20:36 -04001376{
1377 if (mTransformFeedback.id() == transformFeedback)
1378 {
James Darpiniane8a93c62018-01-04 18:02:24 -08001379 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -04001380 mTransformFeedback->onBindingChanged(context, false);
Jamie Madill4928b7c2017-06-20 12:57:39 -04001381 mTransformFeedback.set(context, nullptr);
Corentin Walleza2257da2016-04-19 16:43:12 -04001382 return true;
Shannon Woods53a94a82014-06-24 15:20:36 -04001383 }
Corentin Walleza2257da2016-04-19 16:43:12 -04001384
1385 return false;
Shannon Woods53a94a82014-06-24 15:20:36 -04001386}
1387
Yunchao Hea336b902017-08-02 16:05:21 +08001388void State::setProgramPipelineBinding(const Context *context, ProgramPipeline *pipeline)
1389{
1390 mProgramPipeline.set(context, pipeline);
1391}
1392
1393void State::detachProgramPipeline(const Context *context, GLuint pipeline)
1394{
1395 mProgramPipeline.set(context, nullptr);
1396}
1397
Corentin Wallezad3ae902018-03-09 13:40:42 -05001398bool State::isQueryActive(QueryType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001399{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001400 const Query *query = mActiveQueries[type].get();
1401 if (query != nullptr)
Shannon Woods53a94a82014-06-24 15:20:36 -04001402 {
Corentin Wallezad3ae902018-03-09 13:40:42 -05001403 return true;
1404 }
1405
1406 QueryType alternativeType;
1407 if (GetAlternativeQueryType(type, &alternativeType))
1408 {
1409 query = mActiveQueries[alternativeType].get();
1410 return query != nullptr;
Ian Ewell3ffd78b2016-01-22 16:09:42 -05001411 }
1412
1413 return false;
1414}
1415
1416bool State::isQueryActive(Query *query) const
1417{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001418 for (auto &queryPointer : mActiveQueries)
Ian Ewell3ffd78b2016-01-22 16:09:42 -05001419 {
Corentin Wallezad3ae902018-03-09 13:40:42 -05001420 if (queryPointer.get() == query)
Shannon Woods53a94a82014-06-24 15:20:36 -04001421 {
1422 return true;
1423 }
1424 }
1425
1426 return false;
1427}
1428
Corentin Wallezad3ae902018-03-09 13:40:42 -05001429void State::setActiveQuery(const Context *context, QueryType type, Query *query)
Shannon Woods53a94a82014-06-24 15:20:36 -04001430{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001431 mActiveQueries[type].set(context, query);
Shannon Woods53a94a82014-06-24 15:20:36 -04001432}
1433
Corentin Wallezad3ae902018-03-09 13:40:42 -05001434GLuint State::getActiveQueryId(QueryType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001435{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001436 const Query *query = getActiveQuery(type);
Shannon Woods53a94a82014-06-24 15:20:36 -04001437 return (query ? query->id() : 0u);
1438}
1439
Corentin Wallezad3ae902018-03-09 13:40:42 -05001440Query *State::getActiveQuery(QueryType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001441{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001442 return mActiveQueries[type].get();
Shannon Woods53a94a82014-06-24 15:20:36 -04001443}
1444
Corentin Wallez336129f2017-10-17 15:55:40 -04001445void State::setBufferBinding(const Context *context, BufferBinding target, Buffer *buffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001446{
Corentin Wallez336129f2017-10-17 15:55:40 -04001447 switch (target)
1448 {
1449 case BufferBinding::PixelPack:
Jamie Madillfcfd3382018-09-15 22:30:50 -04001450 UpdateNonTFBufferBinding(context, &mBoundBuffers[target], buffer);
Corentin Wallez336129f2017-10-17 15:55:40 -04001451 mDirtyBits.set(DIRTY_BIT_PACK_BUFFER_BINDING);
1452 break;
1453 case BufferBinding::PixelUnpack:
Jamie Madillfcfd3382018-09-15 22:30:50 -04001454 UpdateNonTFBufferBinding(context, &mBoundBuffers[target], buffer);
Corentin Wallez336129f2017-10-17 15:55:40 -04001455 mDirtyBits.set(DIRTY_BIT_UNPACK_BUFFER_BINDING);
1456 break;
1457 case BufferBinding::DrawIndirect:
Jamie Madillfcfd3382018-09-15 22:30:50 -04001458 UpdateNonTFBufferBinding(context, &mBoundBuffers[target], buffer);
Corentin Wallez336129f2017-10-17 15:55:40 -04001459 mDirtyBits.set(DIRTY_BIT_DRAW_INDIRECT_BUFFER_BINDING);
1460 break;
Qin Jiajiaa98a2812017-11-30 18:12:06 +08001461 case BufferBinding::DispatchIndirect:
Jamie Madillfcfd3382018-09-15 22:30:50 -04001462 UpdateNonTFBufferBinding(context, &mBoundBuffers[target], buffer);
Qin Jiajiaa98a2812017-11-30 18:12:06 +08001463 mDirtyBits.set(DIRTY_BIT_DISPATCH_INDIRECT_BUFFER_BINDING);
1464 break;
Corentin Wallez336129f2017-10-17 15:55:40 -04001465 case BufferBinding::ElementArray:
1466 getVertexArray()->setElementArrayBuffer(context, buffer);
1467 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1468 break;
Xinghua Cao10a4d432017-11-28 14:46:26 +08001469 case BufferBinding::ShaderStorage:
Jamie Madillfcfd3382018-09-15 22:30:50 -04001470 UpdateNonTFBufferBinding(context, &mBoundBuffers[target], buffer);
Xinghua Cao10a4d432017-11-28 14:46:26 +08001471 mDirtyBits.set(DIRTY_BIT_SHADER_STORAGE_BUFFER_BINDING);
1472 break;
jchen1099118c12018-09-10 16:28:51 +08001473 case BufferBinding::Uniform:
1474 UpdateBufferBinding(context, &mBoundBuffers[target], buffer, target);
1475 mDirtyBits.set(DIRTY_BIT_UNIFORM_BUFFER_BINDINGS);
1476 break;
1477 case BufferBinding::AtomicCounter:
1478 UpdateBufferBinding(context, &mBoundBuffers[target], buffer, target);
1479 mDirtyBits.set(DIRTY_BIT_ATOMIC_COUNTER_BUFFER_BINDING);
1480 break;
Corentin Wallez336129f2017-10-17 15:55:40 -04001481 default:
Jamie Madillbf5177d2018-08-21 12:58:20 -04001482 UpdateBufferBinding(context, &mBoundBuffers[target], buffer, target);
Corentin Wallez336129f2017-10-17 15:55:40 -04001483 break;
1484 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001485}
James Darpiniane8a93c62018-01-04 18:02:24 -08001486
Corentin Wallez336129f2017-10-17 15:55:40 -04001487void State::setIndexedBufferBinding(const Context *context,
1488 BufferBinding target,
1489 GLuint index,
1490 Buffer *buffer,
1491 GLintptr offset,
1492 GLsizeiptr size)
Jiajia Qin9d7d0b12016-11-29 16:30:31 +08001493{
Corentin Wallez336129f2017-10-17 15:55:40 -04001494 setBufferBinding(context, target, buffer);
Jiajia Qin9d7d0b12016-11-29 16:30:31 +08001495
Corentin Wallez336129f2017-10-17 15:55:40 -04001496 switch (target)
1497 {
1498 case BufferBinding::TransformFeedback:
1499 mTransformFeedback->bindIndexedBuffer(context, index, buffer, offset, size);
James Darpiniane8a93c62018-01-04 18:02:24 -08001500 setBufferBinding(context, target, buffer);
Corentin Wallez336129f2017-10-17 15:55:40 -04001501 break;
1502 case BufferBinding::Uniform:
Jamie Madillbf5177d2018-08-21 12:58:20 -04001503 UpdateIndexedBufferBinding(context, &mUniformBuffers[index], buffer, target, offset,
1504 size);
Corentin Wallez336129f2017-10-17 15:55:40 -04001505 break;
1506 case BufferBinding::AtomicCounter:
Jamie Madillbf5177d2018-08-21 12:58:20 -04001507 UpdateIndexedBufferBinding(context, &mAtomicCounterBuffers[index], buffer, target,
1508 offset, size);
Corentin Wallez336129f2017-10-17 15:55:40 -04001509 break;
1510 case BufferBinding::ShaderStorage:
Jamie Madillbf5177d2018-08-21 12:58:20 -04001511 UpdateIndexedBufferBinding(context, &mShaderStorageBuffers[index], buffer, target,
1512 offset, size);
Corentin Wallez336129f2017-10-17 15:55:40 -04001513 break;
1514 default:
1515 UNREACHABLE();
1516 break;
1517 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001518}
1519
Geoff Lang5d124a62015-09-15 13:03:27 -04001520const OffsetBindingPointer<Buffer> &State::getIndexedUniformBuffer(size_t index) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001521{
Shannon Woodsf3acaf92014-09-23 18:07:11 -04001522 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
Geoff Lang5d124a62015-09-15 13:03:27 -04001523 return mUniformBuffers[index];
Gregoire Payen de La Garanderie68694e92015-03-24 14:03:37 +00001524}
1525
Jiajia Qin6eafb042016-12-27 17:04:07 +08001526const OffsetBindingPointer<Buffer> &State::getIndexedAtomicCounterBuffer(size_t index) const
1527{
1528 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
1529 return mAtomicCounterBuffers[index];
1530}
1531
Jiajia Qinf546e7d2017-03-27 14:12:59 +08001532const OffsetBindingPointer<Buffer> &State::getIndexedShaderStorageBuffer(size_t index) const
1533{
1534 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
1535 return mShaderStorageBuffers[index];
1536}
1537
Corentin Wallez336129f2017-10-17 15:55:40 -04001538Buffer *State::getTargetBuffer(BufferBinding target) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001539{
1540 switch (target)
1541 {
Corentin Wallez336129f2017-10-17 15:55:40 -04001542 case BufferBinding::ElementArray:
1543 return getVertexArray()->getElementArrayBuffer().get();
Corentin Wallez336129f2017-10-17 15:55:40 -04001544 default:
1545 return mBoundBuffers[target].get();
Shannon Woods53a94a82014-06-24 15:20:36 -04001546 }
1547}
1548
James Darpinian4d9d4832018-03-13 12:43:28 -07001549void State::detachBuffer(const Context *context, const Buffer *buffer)
Yuly Novikov5807a532015-12-03 13:01:22 -05001550{
James Darpinian4d9d4832018-03-13 12:43:28 -07001551 if (!buffer->isBound())
1552 {
1553 return;
1554 }
1555 GLuint bufferName = buffer->id();
James Darpiniane8a93c62018-01-04 18:02:24 -08001556 for (auto target : angle::AllEnums<BufferBinding>())
Yuly Novikov5807a532015-12-03 13:01:22 -05001557 {
James Darpiniane8a93c62018-01-04 18:02:24 -08001558 if (mBoundBuffers[target].id() == bufferName)
Yuly Novikov5807a532015-12-03 13:01:22 -05001559 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001560 UpdateBufferBinding(context, &mBoundBuffers[target], nullptr, target);
Yuly Novikov5807a532015-12-03 13:01:22 -05001561 }
1562 }
1563
1564 TransformFeedback *curTransformFeedback = getCurrentTransformFeedback();
1565 if (curTransformFeedback)
1566 {
Jamie Madill4928b7c2017-06-20 12:57:39 -04001567 curTransformFeedback->detachBuffer(context, bufferName);
Yuly Novikov5807a532015-12-03 13:01:22 -05001568 }
1569
Jamie Madill4928b7c2017-06-20 12:57:39 -04001570 getVertexArray()->detachBuffer(context, bufferName);
James Darpiniane8a93c62018-01-04 18:02:24 -08001571
1572 for (auto &buf : mUniformBuffers)
1573 {
1574 if (buf.id() == bufferName)
1575 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001576 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::Uniform, 0, 0);
James Darpiniane8a93c62018-01-04 18:02:24 -08001577 }
1578 }
1579
1580 for (auto &buf : mAtomicCounterBuffers)
1581 {
1582 if (buf.id() == bufferName)
1583 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001584 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::AtomicCounter, 0, 0);
James Darpiniane8a93c62018-01-04 18:02:24 -08001585 }
1586 }
1587
1588 for (auto &buf : mShaderStorageBuffers)
1589 {
1590 if (buf.id() == bufferName)
1591 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001592 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::ShaderStorage, 0, 0);
James Darpiniane8a93c62018-01-04 18:02:24 -08001593 }
1594 }
Yuly Novikov5807a532015-12-03 13:01:22 -05001595}
1596
Shannon Woods53a94a82014-06-24 15:20:36 -04001597void State::setEnableVertexAttribArray(unsigned int attribNum, bool enabled)
1598{
1599 getVertexArray()->enableAttribute(attribNum, enabled);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001600 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001601}
1602
1603void State::setVertexAttribf(GLuint index, const GLfloat values[4])
1604{
Shannon Woods23e05002014-09-22 19:07:27 -04001605 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001606 mVertexAttribCurrentValues[index].setFloatValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001607 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1608 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001609 mCurrentValuesTypeMask.setIndex(GL_FLOAT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001610}
1611
1612void State::setVertexAttribu(GLuint index, const GLuint values[4])
1613{
Shannon Woods23e05002014-09-22 19:07:27 -04001614 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001615 mVertexAttribCurrentValues[index].setUnsignedIntValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001616 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1617 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001618 mCurrentValuesTypeMask.setIndex(GL_UNSIGNED_INT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001619}
1620
1621void State::setVertexAttribi(GLuint index, const GLint values[4])
1622{
Shannon Woods23e05002014-09-22 19:07:27 -04001623 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001624 mVertexAttribCurrentValues[index].setIntValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001625 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1626 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001627 mCurrentValuesTypeMask.setIndex(GL_INT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001628}
1629
Shaodde78e82017-05-22 14:13:27 +08001630void State::setVertexAttribPointer(const Context *context,
1631 unsigned int attribNum,
1632 Buffer *boundBuffer,
1633 GLint size,
1634 GLenum type,
1635 bool normalized,
1636 bool pureInteger,
1637 GLsizei stride,
1638 const void *pointer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001639{
Shaodde78e82017-05-22 14:13:27 +08001640 getVertexArray()->setVertexAttribPointer(context, attribNum, boundBuffer, size, type,
1641 normalized, pureInteger, stride, pointer);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001642 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Jamie Madill0b9e9032015-08-17 11:51:52 +00001643}
1644
Shaodde78e82017-05-22 14:13:27 +08001645void State::setVertexAttribDivisor(const Context *context, GLuint index, GLuint divisor)
Jamie Madill0b9e9032015-08-17 11:51:52 +00001646{
Shaodde78e82017-05-22 14:13:27 +08001647 getVertexArray()->setVertexAttribDivisor(context, index, divisor);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001648 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001649}
1650
Jamie Madill6de51852017-04-12 09:53:01 -04001651const VertexAttribCurrentValueData &State::getVertexAttribCurrentValue(size_t attribNum) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001652{
Jamie Madill6de51852017-04-12 09:53:01 -04001653 ASSERT(attribNum < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001654 return mVertexAttribCurrentValues[attribNum];
1655}
1656
Jamie Madillcac94a92017-11-10 10:09:32 -05001657const std::vector<VertexAttribCurrentValueData> &State::getVertexAttribCurrentValues() const
1658{
1659 return mVertexAttribCurrentValues;
1660}
1661
Shannon Woods53a94a82014-06-24 15:20:36 -04001662const void *State::getVertexAttribPointer(unsigned int attribNum) const
1663{
1664 return getVertexArray()->getVertexAttribute(attribNum).pointer;
1665}
1666
1667void State::setPackAlignment(GLint alignment)
1668{
1669 mPack.alignment = alignment;
Jamie Madillc67323a2017-11-02 23:11:41 -04001670 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001671}
1672
1673GLint State::getPackAlignment() const
1674{
1675 return mPack.alignment;
1676}
1677
1678void State::setPackReverseRowOrder(bool reverseRowOrder)
1679{
1680 mPack.reverseRowOrder = reverseRowOrder;
Jamie Madillc67323a2017-11-02 23:11:41 -04001681 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001682}
1683
1684bool State::getPackReverseRowOrder() const
1685{
1686 return mPack.reverseRowOrder;
1687}
1688
Minmin Gongadff67b2015-10-14 10:34:45 -04001689void State::setPackRowLength(GLint rowLength)
1690{
1691 mPack.rowLength = rowLength;
Jamie Madillc67323a2017-11-02 23:11:41 -04001692 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001693}
1694
1695GLint State::getPackRowLength() const
1696{
1697 return mPack.rowLength;
1698}
1699
1700void State::setPackSkipRows(GLint skipRows)
1701{
1702 mPack.skipRows = skipRows;
Jamie Madillc67323a2017-11-02 23:11:41 -04001703 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001704}
1705
1706GLint State::getPackSkipRows() const
1707{
1708 return mPack.skipRows;
1709}
1710
1711void State::setPackSkipPixels(GLint skipPixels)
1712{
1713 mPack.skipPixels = skipPixels;
Jamie Madillc67323a2017-11-02 23:11:41 -04001714 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001715}
1716
1717GLint State::getPackSkipPixels() const
1718{
1719 return mPack.skipPixels;
1720}
1721
Shannon Woods53a94a82014-06-24 15:20:36 -04001722const PixelPackState &State::getPackState() const
1723{
1724 return mPack;
1725}
1726
Jamie Madill87de3622015-03-16 10:41:44 -04001727PixelPackState &State::getPackState()
1728{
1729 return mPack;
1730}
1731
Shannon Woods53a94a82014-06-24 15:20:36 -04001732void State::setUnpackAlignment(GLint alignment)
1733{
1734 mUnpack.alignment = alignment;
Jamie Madillc67323a2017-11-02 23:11:41 -04001735 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001736}
1737
1738GLint State::getUnpackAlignment() const
1739{
1740 return mUnpack.alignment;
1741}
1742
Minmin Gongb8aee3b2015-01-27 14:42:36 -08001743void State::setUnpackRowLength(GLint rowLength)
1744{
1745 mUnpack.rowLength = rowLength;
Jamie Madillc67323a2017-11-02 23:11:41 -04001746 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongb8aee3b2015-01-27 14:42:36 -08001747}
1748
1749GLint State::getUnpackRowLength() const
1750{
1751 return mUnpack.rowLength;
1752}
1753
Minmin Gongadff67b2015-10-14 10:34:45 -04001754void State::setUnpackImageHeight(GLint imageHeight)
1755{
1756 mUnpack.imageHeight = imageHeight;
Jamie Madillc67323a2017-11-02 23:11:41 -04001757 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001758}
1759
1760GLint State::getUnpackImageHeight() const
1761{
1762 return mUnpack.imageHeight;
1763}
1764
1765void State::setUnpackSkipImages(GLint skipImages)
1766{
1767 mUnpack.skipImages = skipImages;
Jamie Madillc67323a2017-11-02 23:11:41 -04001768 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001769}
1770
1771GLint State::getUnpackSkipImages() const
1772{
1773 return mUnpack.skipImages;
1774}
1775
1776void State::setUnpackSkipRows(GLint skipRows)
1777{
1778 mUnpack.skipRows = skipRows;
Jamie Madillc67323a2017-11-02 23:11:41 -04001779 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001780}
1781
1782GLint State::getUnpackSkipRows() const
1783{
1784 return mUnpack.skipRows;
1785}
1786
1787void State::setUnpackSkipPixels(GLint skipPixels)
1788{
1789 mUnpack.skipPixels = skipPixels;
Jamie Madillc67323a2017-11-02 23:11:41 -04001790 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001791}
1792
1793GLint State::getUnpackSkipPixels() const
1794{
1795 return mUnpack.skipPixels;
1796}
1797
Shannon Woods53a94a82014-06-24 15:20:36 -04001798const PixelUnpackState &State::getUnpackState() const
1799{
1800 return mUnpack;
1801}
1802
Jamie Madill67102f02015-03-16 10:41:42 -04001803PixelUnpackState &State::getUnpackState()
1804{
1805 return mUnpack;
1806}
1807
Geoff Lang70d0f492015-12-10 17:45:46 -05001808const Debug &State::getDebug() const
1809{
1810 return mDebug;
1811}
1812
1813Debug &State::getDebug()
1814{
1815 return mDebug;
1816}
1817
Sami Väisänena797e062016-05-12 15:23:40 +03001818void State::setCoverageModulation(GLenum components)
1819{
1820 mCoverageModulation = components;
1821 mDirtyBits.set(DIRTY_BIT_COVERAGE_MODULATION);
1822}
1823
1824GLenum State::getCoverageModulation() const
1825{
1826 return mCoverageModulation;
1827}
1828
Sami Väisänene45e53b2016-05-25 10:36:04 +03001829void State::loadPathRenderingMatrix(GLenum matrixMode, const GLfloat *matrix)
1830{
1831 if (matrixMode == GL_PATH_MODELVIEW_CHROMIUM)
1832 {
1833 memcpy(mPathMatrixMV, matrix, 16 * sizeof(GLfloat));
jchen10bb2f2c42018-09-16 09:47:38 +08001834 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING);
Sami Väisänene45e53b2016-05-25 10:36:04 +03001835 }
1836 else if (matrixMode == GL_PATH_PROJECTION_CHROMIUM)
1837 {
1838 memcpy(mPathMatrixProj, matrix, 16 * sizeof(GLfloat));
jchen10bb2f2c42018-09-16 09:47:38 +08001839 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING);
Sami Väisänene45e53b2016-05-25 10:36:04 +03001840 }
1841 else
1842 {
1843 UNREACHABLE();
1844 }
1845}
1846
1847const GLfloat *State::getPathRenderingMatrix(GLenum which) const
1848{
1849 if (which == GL_PATH_MODELVIEW_MATRIX_CHROMIUM)
1850 {
1851 return mPathMatrixMV;
1852 }
1853 else if (which == GL_PATH_PROJECTION_MATRIX_CHROMIUM)
1854 {
1855 return mPathMatrixProj;
1856 }
1857
1858 UNREACHABLE();
1859 return nullptr;
1860}
1861
1862void State::setPathStencilFunc(GLenum func, GLint ref, GLuint mask)
1863{
1864 mPathStencilFunc = func;
1865 mPathStencilRef = ref;
1866 mPathStencilMask = mask;
jchen10bb2f2c42018-09-16 09:47:38 +08001867 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING);
Sami Väisänene45e53b2016-05-25 10:36:04 +03001868}
1869
1870GLenum State::getPathStencilFunc() const
1871{
1872 return mPathStencilFunc;
1873}
1874
1875GLint State::getPathStencilRef() const
1876{
1877 return mPathStencilRef;
1878}
1879
1880GLuint State::getPathStencilMask() const
1881{
1882 return mPathStencilMask;
1883}
1884
Geoff Lang1d2c41d2016-10-19 16:14:46 -07001885void State::setFramebufferSRGB(bool sRGB)
1886{
1887 mFramebufferSRGB = sRGB;
1888 mDirtyBits.set(DIRTY_BIT_FRAMEBUFFER_SRGB);
1889}
1890
1891bool State::getFramebufferSRGB() const
1892{
1893 return mFramebufferSRGB;
1894}
1895
jchen1082af6202018-06-22 10:59:52 +08001896void State::setMaxShaderCompilerThreads(GLuint count)
1897{
1898 mMaxShaderCompilerThreads = count;
1899}
1900
1901GLuint State::getMaxShaderCompilerThreads() const
1902{
1903 return mMaxShaderCompilerThreads;
1904}
1905
Shannon Woods53a94a82014-06-24 15:20:36 -04001906void State::getBooleanv(GLenum pname, GLboolean *params)
1907{
1908 switch (pname)
1909 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001910 case GL_SAMPLE_COVERAGE_INVERT:
1911 *params = mSampleCoverageInvert;
1912 break;
1913 case GL_DEPTH_WRITEMASK:
1914 *params = mDepthStencil.depthMask;
1915 break;
1916 case GL_COLOR_WRITEMASK:
1917 params[0] = mBlend.colorMaskRed;
1918 params[1] = mBlend.colorMaskGreen;
1919 params[2] = mBlend.colorMaskBlue;
1920 params[3] = mBlend.colorMaskAlpha;
1921 break;
1922 case GL_CULL_FACE:
1923 *params = mRasterizer.cullFace;
1924 break;
1925 case GL_POLYGON_OFFSET_FILL:
1926 *params = mRasterizer.polygonOffsetFill;
1927 break;
1928 case GL_SAMPLE_ALPHA_TO_COVERAGE:
1929 *params = mBlend.sampleAlphaToCoverage;
1930 break;
1931 case GL_SAMPLE_COVERAGE:
1932 *params = mSampleCoverage;
1933 break;
1934 case GL_SAMPLE_MASK:
1935 *params = mSampleMask;
1936 break;
1937 case GL_SCISSOR_TEST:
1938 *params = mScissorTest;
1939 break;
1940 case GL_STENCIL_TEST:
1941 *params = mDepthStencil.stencilTest;
1942 break;
1943 case GL_DEPTH_TEST:
1944 *params = mDepthStencil.depthTest;
1945 break;
1946 case GL_BLEND:
1947 *params = mBlend.blend;
1948 break;
1949 case GL_DITHER:
1950 *params = mBlend.dither;
1951 break;
1952 case GL_TRANSFORM_FEEDBACK_ACTIVE:
1953 *params = getCurrentTransformFeedback()->isActive() ? GL_TRUE : GL_FALSE;
1954 break;
1955 case GL_TRANSFORM_FEEDBACK_PAUSED:
1956 *params = getCurrentTransformFeedback()->isPaused() ? GL_TRUE : GL_FALSE;
1957 break;
1958 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
1959 *params = mPrimitiveRestart;
1960 break;
1961 case GL_RASTERIZER_DISCARD:
1962 *params = isRasterizerDiscardEnabled() ? GL_TRUE : GL_FALSE;
1963 break;
1964 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
1965 *params = mDebug.isOutputSynchronous() ? GL_TRUE : GL_FALSE;
1966 break;
1967 case GL_DEBUG_OUTPUT:
1968 *params = mDebug.isOutputEnabled() ? GL_TRUE : GL_FALSE;
1969 break;
1970 case GL_MULTISAMPLE_EXT:
1971 *params = mMultiSampling;
1972 break;
1973 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
1974 *params = mSampleAlphaToOne;
1975 break;
1976 case GL_BIND_GENERATES_RESOURCE_CHROMIUM:
1977 *params = isBindGeneratesResourceEnabled() ? GL_TRUE : GL_FALSE;
1978 break;
1979 case GL_CLIENT_ARRAYS_ANGLE:
1980 *params = areClientArraysEnabled() ? GL_TRUE : GL_FALSE;
1981 break;
1982 case GL_FRAMEBUFFER_SRGB_EXT:
1983 *params = getFramebufferSRGB() ? GL_TRUE : GL_FALSE;
1984 break;
1985 case GL_ROBUST_RESOURCE_INITIALIZATION_ANGLE:
1986 *params = mRobustResourceInit ? GL_TRUE : GL_FALSE;
1987 break;
1988 case GL_PROGRAM_CACHE_ENABLED_ANGLE:
1989 *params = mProgramBinaryCacheEnabled ? GL_TRUE : GL_FALSE;
1990 break;
Lingfeng Yangd0febe72018-05-17 22:36:52 -07001991 case GL_LIGHT_MODEL_TWO_SIDE:
1992 *params = IsLightModelTwoSided(&mGLES1State);
1993 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001994 default:
1995 UNREACHABLE();
1996 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04001997 }
1998}
1999
2000void State::getFloatv(GLenum pname, GLfloat *params)
2001{
2002 // Please note: DEPTH_CLEAR_VALUE is included in our internal getFloatv implementation
2003 // because it is stored as a float, despite the fact that the GL ES 2.0 spec names
2004 // GetIntegerv as its native query function. As it would require conversion in any
2005 // case, this should make no difference to the calling application.
2006 switch (pname)
2007 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002008 case GL_LINE_WIDTH:
2009 *params = mLineWidth;
2010 break;
2011 case GL_SAMPLE_COVERAGE_VALUE:
2012 *params = mSampleCoverageValue;
2013 break;
2014 case GL_DEPTH_CLEAR_VALUE:
2015 *params = mDepthClearValue;
2016 break;
2017 case GL_POLYGON_OFFSET_FACTOR:
2018 *params = mRasterizer.polygonOffsetFactor;
2019 break;
2020 case GL_POLYGON_OFFSET_UNITS:
2021 *params = mRasterizer.polygonOffsetUnits;
2022 break;
2023 case GL_DEPTH_RANGE:
2024 params[0] = mNearZ;
2025 params[1] = mFarZ;
2026 break;
2027 case GL_COLOR_CLEAR_VALUE:
2028 params[0] = mColorClearValue.red;
2029 params[1] = mColorClearValue.green;
2030 params[2] = mColorClearValue.blue;
2031 params[3] = mColorClearValue.alpha;
2032 break;
2033 case GL_BLEND_COLOR:
2034 params[0] = mBlendColor.red;
2035 params[1] = mBlendColor.green;
2036 params[2] = mBlendColor.blue;
2037 params[3] = mBlendColor.alpha;
2038 break;
2039 case GL_MULTISAMPLE_EXT:
2040 *params = static_cast<GLfloat>(mMultiSampling);
2041 break;
2042 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
2043 *params = static_cast<GLfloat>(mSampleAlphaToOne);
2044 break;
2045 case GL_COVERAGE_MODULATION_CHROMIUM:
2046 params[0] = static_cast<GLfloat>(mCoverageModulation);
2047 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -07002048 case GL_ALPHA_TEST_REF:
2049 *params = mGLES1State.mAlphaTestRef;
2050 break;
Lingfeng Yanga43994c2018-03-29 07:21:41 -07002051 case GL_CURRENT_COLOR:
2052 {
2053 const auto &color = mGLES1State.mCurrentColor;
2054 params[0] = color.red;
2055 params[1] = color.green;
2056 params[2] = color.blue;
2057 params[3] = color.alpha;
2058 break;
2059 }
Lingfeng Yang5a7e61b2018-03-29 16:50:32 -07002060 case GL_CURRENT_NORMAL:
2061 {
2062 const auto &normal = mGLES1State.mCurrentNormal;
2063 params[0] = normal[0];
2064 params[1] = normal[1];
2065 params[2] = normal[2];
2066 break;
2067 }
Lingfeng Yang038dd532018-03-29 17:31:52 -07002068 case GL_CURRENT_TEXTURE_COORDS:
2069 {
2070 const auto &texcoord = mGLES1State.mCurrentTextureCoords[mActiveSampler];
2071 params[0] = texcoord.s;
2072 params[1] = texcoord.t;
2073 params[2] = texcoord.r;
2074 params[3] = texcoord.q;
2075 break;
2076 }
Lingfeng Yang3a41af62018-04-09 07:28:56 -07002077 case GL_MODELVIEW_MATRIX:
2078 memcpy(params, mGLES1State.mModelviewMatrices.back().data(), 16 * sizeof(GLfloat));
2079 break;
2080 case GL_PROJECTION_MATRIX:
2081 memcpy(params, mGLES1State.mProjectionMatrices.back().data(), 16 * sizeof(GLfloat));
2082 break;
2083 case GL_TEXTURE_MATRIX:
2084 memcpy(params, mGLES1State.mTextureMatrices[mActiveSampler].back().data(),
2085 16 * sizeof(GLfloat));
2086 break;
Lingfeng Yangd0febe72018-05-17 22:36:52 -07002087 case GL_LIGHT_MODEL_AMBIENT:
2088 GetLightModelParameters(&mGLES1State, pname, params);
2089 break;
Lingfeng Yang7ba3f422018-06-01 09:43:04 -07002090 case GL_FOG_MODE:
2091 case GL_FOG_DENSITY:
2092 case GL_FOG_START:
2093 case GL_FOG_END:
2094 case GL_FOG_COLOR:
2095 GetFogParameters(&mGLES1State, pname, params);
2096 break;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -07002097 case GL_POINT_SIZE:
2098 GetPointSize(&mGLES1State, params);
2099 break;
2100 case GL_POINT_SIZE_MIN:
2101 case GL_POINT_SIZE_MAX:
2102 case GL_POINT_FADE_THRESHOLD_SIZE:
2103 case GL_POINT_DISTANCE_ATTENUATION:
2104 GetPointParameter(&mGLES1State, FromGLenum<PointParameter>(pname), params);
2105 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002106 default:
2107 UNREACHABLE();
2108 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002109 }
2110}
2111
Jamie Madille98b1b52018-03-08 09:47:23 -05002112Error State::getIntegerv(const Context *context, GLenum pname, GLint *params)
Shannon Woods53a94a82014-06-24 15:20:36 -04002113{
2114 if (pname >= GL_DRAW_BUFFER0_EXT && pname <= GL_DRAW_BUFFER15_EXT)
2115 {
2116 unsigned int colorAttachment = (pname - GL_DRAW_BUFFER0_EXT);
Shannon Woods2df6a602014-09-26 16:12:07 -04002117 ASSERT(colorAttachment < mMaxDrawBuffers);
Shannon Woods53a94a82014-06-24 15:20:36 -04002118 Framebuffer *framebuffer = mDrawFramebuffer;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002119 *params = framebuffer->getDrawBufferState(colorAttachment);
Jamie Madille98b1b52018-03-08 09:47:23 -05002120 return NoError();
Shannon Woods53a94a82014-06-24 15:20:36 -04002121 }
2122
2123 // Please note: DEPTH_CLEAR_VALUE is not included in our internal getIntegerv implementation
2124 // because it is stored as a float, despite the fact that the GL ES 2.0 spec names
2125 // GetIntegerv as its native query function. As it would require conversion in any
2126 // case, this should make no difference to the calling application. You may find it in
2127 // State::getFloatv.
2128 switch (pname)
2129 {
Corentin Wallez336129f2017-10-17 15:55:40 -04002130 case GL_ARRAY_BUFFER_BINDING:
2131 *params = mBoundBuffers[BufferBinding::Array].id();
2132 break;
2133 case GL_DRAW_INDIRECT_BUFFER_BINDING:
2134 *params = mBoundBuffers[BufferBinding::DrawIndirect].id();
2135 break;
2136 case GL_ELEMENT_ARRAY_BUFFER_BINDING:
2137 *params = getVertexArray()->getElementArrayBuffer().id();
2138 break;
Jamie Madill690c8eb2018-03-12 15:20:03 -04002139 case GL_DRAW_FRAMEBUFFER_BINDING:
2140 static_assert(GL_DRAW_FRAMEBUFFER_BINDING == GL_DRAW_FRAMEBUFFER_BINDING_ANGLE,
2141 "Enum mismatch");
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002142 *params = mDrawFramebuffer->id();
2143 break;
Jamie Madill690c8eb2018-03-12 15:20:03 -04002144 case GL_READ_FRAMEBUFFER_BINDING:
2145 static_assert(GL_READ_FRAMEBUFFER_BINDING == GL_READ_FRAMEBUFFER_BINDING_ANGLE,
2146 "Enum mismatch");
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002147 *params = mReadFramebuffer->id();
2148 break;
2149 case GL_RENDERBUFFER_BINDING:
2150 *params = mRenderbuffer.id();
2151 break;
2152 case GL_VERTEX_ARRAY_BINDING:
2153 *params = mVertexArray->id();
2154 break;
2155 case GL_CURRENT_PROGRAM:
2156 *params = mProgram ? mProgram->id() : 0;
2157 break;
2158 case GL_PACK_ALIGNMENT:
2159 *params = mPack.alignment;
2160 break;
2161 case GL_PACK_REVERSE_ROW_ORDER_ANGLE:
2162 *params = mPack.reverseRowOrder;
2163 break;
2164 case GL_PACK_ROW_LENGTH:
2165 *params = mPack.rowLength;
2166 break;
2167 case GL_PACK_SKIP_ROWS:
2168 *params = mPack.skipRows;
2169 break;
2170 case GL_PACK_SKIP_PIXELS:
2171 *params = mPack.skipPixels;
2172 break;
2173 case GL_UNPACK_ALIGNMENT:
2174 *params = mUnpack.alignment;
2175 break;
2176 case GL_UNPACK_ROW_LENGTH:
2177 *params = mUnpack.rowLength;
2178 break;
2179 case GL_UNPACK_IMAGE_HEIGHT:
2180 *params = mUnpack.imageHeight;
2181 break;
2182 case GL_UNPACK_SKIP_IMAGES:
2183 *params = mUnpack.skipImages;
2184 break;
2185 case GL_UNPACK_SKIP_ROWS:
2186 *params = mUnpack.skipRows;
2187 break;
2188 case GL_UNPACK_SKIP_PIXELS:
2189 *params = mUnpack.skipPixels;
2190 break;
2191 case GL_GENERATE_MIPMAP_HINT:
2192 *params = mGenerateMipmapHint;
2193 break;
2194 case GL_FRAGMENT_SHADER_DERIVATIVE_HINT_OES:
2195 *params = mFragmentShaderDerivativeHint;
2196 break;
2197 case GL_ACTIVE_TEXTURE:
2198 *params = (static_cast<GLint>(mActiveSampler) + GL_TEXTURE0);
2199 break;
2200 case GL_STENCIL_FUNC:
2201 *params = mDepthStencil.stencilFunc;
2202 break;
2203 case GL_STENCIL_REF:
2204 *params = mStencilRef;
2205 break;
2206 case GL_STENCIL_VALUE_MASK:
2207 *params = CastMaskValue(context, mDepthStencil.stencilMask);
2208 break;
2209 case GL_STENCIL_BACK_FUNC:
2210 *params = mDepthStencil.stencilBackFunc;
2211 break;
2212 case GL_STENCIL_BACK_REF:
2213 *params = mStencilBackRef;
2214 break;
2215 case GL_STENCIL_BACK_VALUE_MASK:
2216 *params = CastMaskValue(context, mDepthStencil.stencilBackMask);
2217 break;
2218 case GL_STENCIL_FAIL:
2219 *params = mDepthStencil.stencilFail;
2220 break;
2221 case GL_STENCIL_PASS_DEPTH_FAIL:
2222 *params = mDepthStencil.stencilPassDepthFail;
2223 break;
2224 case GL_STENCIL_PASS_DEPTH_PASS:
2225 *params = mDepthStencil.stencilPassDepthPass;
2226 break;
2227 case GL_STENCIL_BACK_FAIL:
2228 *params = mDepthStencil.stencilBackFail;
2229 break;
2230 case GL_STENCIL_BACK_PASS_DEPTH_FAIL:
2231 *params = mDepthStencil.stencilBackPassDepthFail;
2232 break;
2233 case GL_STENCIL_BACK_PASS_DEPTH_PASS:
2234 *params = mDepthStencil.stencilBackPassDepthPass;
2235 break;
2236 case GL_DEPTH_FUNC:
2237 *params = mDepthStencil.depthFunc;
2238 break;
2239 case GL_BLEND_SRC_RGB:
2240 *params = mBlend.sourceBlendRGB;
2241 break;
2242 case GL_BLEND_SRC_ALPHA:
2243 *params = mBlend.sourceBlendAlpha;
2244 break;
2245 case GL_BLEND_DST_RGB:
2246 *params = mBlend.destBlendRGB;
2247 break;
2248 case GL_BLEND_DST_ALPHA:
2249 *params = mBlend.destBlendAlpha;
2250 break;
2251 case GL_BLEND_EQUATION_RGB:
2252 *params = mBlend.blendEquationRGB;
2253 break;
2254 case GL_BLEND_EQUATION_ALPHA:
2255 *params = mBlend.blendEquationAlpha;
2256 break;
2257 case GL_STENCIL_WRITEMASK:
2258 *params = CastMaskValue(context, mDepthStencil.stencilWritemask);
2259 break;
2260 case GL_STENCIL_BACK_WRITEMASK:
2261 *params = CastMaskValue(context, mDepthStencil.stencilBackWritemask);
2262 break;
2263 case GL_STENCIL_CLEAR_VALUE:
2264 *params = mStencilClearValue;
2265 break;
2266 case GL_IMPLEMENTATION_COLOR_READ_TYPE:
Jamie Madill690c8eb2018-03-12 15:20:03 -04002267 ANGLE_TRY(mReadFramebuffer->getImplementationColorReadType(
2268 context, reinterpret_cast<GLenum *>(params)));
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002269 break;
2270 case GL_IMPLEMENTATION_COLOR_READ_FORMAT:
Jamie Madill690c8eb2018-03-12 15:20:03 -04002271 ANGLE_TRY(mReadFramebuffer->getImplementationColorReadFormat(
2272 context, reinterpret_cast<GLenum *>(params)));
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002273 break;
2274 case GL_SAMPLE_BUFFERS:
2275 case GL_SAMPLES:
Shannon Woods53a94a82014-06-24 15:20:36 -04002276 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002277 Framebuffer *framebuffer = mDrawFramebuffer;
Jamie Madill427064d2018-04-13 16:20:34 -04002278 if (framebuffer->isComplete(context))
Shannon Woods53a94a82014-06-24 15:20:36 -04002279 {
Jamie Madill427064d2018-04-13 16:20:34 -04002280 GLint samples = framebuffer->getSamples(context);
Shannon Woods53a94a82014-06-24 15:20:36 -04002281 switch (pname)
2282 {
Jamie Madilla0016b72017-07-14 14:30:46 -04002283 case GL_SAMPLE_BUFFERS:
Jamie Madille98b1b52018-03-08 09:47:23 -05002284 if (samples != 0)
Jamie Madilla0016b72017-07-14 14:30:46 -04002285 {
2286 *params = 1;
2287 }
2288 else
2289 {
2290 *params = 0;
2291 }
2292 break;
2293 case GL_SAMPLES:
Jamie Madille98b1b52018-03-08 09:47:23 -05002294 *params = samples;
Jamie Madilla0016b72017-07-14 14:30:46 -04002295 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002296 }
2297 }
2298 else
2299 {
2300 *params = 0;
2301 }
2302 }
2303 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002304 case GL_VIEWPORT:
2305 params[0] = mViewport.x;
2306 params[1] = mViewport.y;
2307 params[2] = mViewport.width;
2308 params[3] = mViewport.height;
2309 break;
2310 case GL_SCISSOR_BOX:
2311 params[0] = mScissor.x;
2312 params[1] = mScissor.y;
2313 params[2] = mScissor.width;
2314 params[3] = mScissor.height;
2315 break;
2316 case GL_CULL_FACE_MODE:
2317 *params = ToGLenum(mRasterizer.cullMode);
2318 break;
2319 case GL_FRONT_FACE:
2320 *params = mRasterizer.frontFace;
2321 break;
2322 case GL_RED_BITS:
2323 case GL_GREEN_BITS:
2324 case GL_BLUE_BITS:
2325 case GL_ALPHA_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002326 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002327 Framebuffer *framebuffer = getDrawFramebuffer();
2328 const FramebufferAttachment *colorbuffer = framebuffer->getFirstColorbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002329
2330 if (colorbuffer)
2331 {
2332 switch (pname)
2333 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002334 case GL_RED_BITS:
2335 *params = colorbuffer->getRedSize();
2336 break;
2337 case GL_GREEN_BITS:
2338 *params = colorbuffer->getGreenSize();
2339 break;
2340 case GL_BLUE_BITS:
2341 *params = colorbuffer->getBlueSize();
2342 break;
2343 case GL_ALPHA_BITS:
2344 *params = colorbuffer->getAlphaSize();
2345 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002346 }
2347 }
2348 else
2349 {
2350 *params = 0;
2351 }
2352 }
2353 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002354 case GL_DEPTH_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002355 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002356 const Framebuffer *framebuffer = getDrawFramebuffer();
2357 const FramebufferAttachment *depthbuffer = framebuffer->getDepthbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002358
2359 if (depthbuffer)
2360 {
2361 *params = depthbuffer->getDepthSize();
2362 }
2363 else
2364 {
2365 *params = 0;
2366 }
2367 }
2368 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002369 case GL_STENCIL_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002370 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002371 const Framebuffer *framebuffer = getDrawFramebuffer();
2372 const FramebufferAttachment *stencilbuffer = framebuffer->getStencilbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002373
2374 if (stencilbuffer)
2375 {
2376 *params = stencilbuffer->getStencilSize();
2377 }
2378 else
2379 {
2380 *params = 0;
2381 }
2382 }
2383 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002384 case GL_TEXTURE_BINDING_2D:
2385 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2386 *params =
2387 getSamplerTextureId(static_cast<unsigned int>(mActiveSampler), TextureType::_2D);
2388 break;
2389 case GL_TEXTURE_BINDING_RECTANGLE_ANGLE:
2390 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2391 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2392 TextureType::Rectangle);
2393 break;
2394 case GL_TEXTURE_BINDING_CUBE_MAP:
2395 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2396 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2397 TextureType::CubeMap);
2398 break;
2399 case GL_TEXTURE_BINDING_3D:
2400 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2401 *params =
2402 getSamplerTextureId(static_cast<unsigned int>(mActiveSampler), TextureType::_3D);
2403 break;
2404 case GL_TEXTURE_BINDING_2D_ARRAY:
2405 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2406 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2407 TextureType::_2DArray);
2408 break;
2409 case GL_TEXTURE_BINDING_2D_MULTISAMPLE:
2410 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2411 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2412 TextureType::_2DMultisample);
2413 break;
Olli Etuahodff32a02018-08-28 14:35:50 +03002414 case GL_TEXTURE_BINDING_2D_MULTISAMPLE_ARRAY:
2415 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2416 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2417 TextureType::_2DMultisampleArray);
2418 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002419 case GL_TEXTURE_BINDING_EXTERNAL_OES:
2420 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2421 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2422 TextureType::External);
2423 break;
2424 case GL_UNIFORM_BUFFER_BINDING:
2425 *params = mBoundBuffers[BufferBinding::Uniform].id();
2426 break;
2427 case GL_TRANSFORM_FEEDBACK_BINDING:
2428 *params = mTransformFeedback.id();
2429 break;
2430 case GL_TRANSFORM_FEEDBACK_BUFFER_BINDING:
2431 *params = mBoundBuffers[BufferBinding::TransformFeedback].id();
2432 break;
2433 case GL_COPY_READ_BUFFER_BINDING:
2434 *params = mBoundBuffers[BufferBinding::CopyRead].id();
2435 break;
2436 case GL_COPY_WRITE_BUFFER_BINDING:
2437 *params = mBoundBuffers[BufferBinding::CopyWrite].id();
2438 break;
2439 case GL_PIXEL_PACK_BUFFER_BINDING:
2440 *params = mBoundBuffers[BufferBinding::PixelPack].id();
2441 break;
2442 case GL_PIXEL_UNPACK_BUFFER_BINDING:
2443 *params = mBoundBuffers[BufferBinding::PixelUnpack].id();
2444 break;
2445 case GL_READ_BUFFER:
2446 *params = mReadFramebuffer->getReadBufferState();
2447 break;
2448 case GL_SAMPLER_BINDING:
2449 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2450 *params = getSamplerId(static_cast<GLuint>(mActiveSampler));
2451 break;
2452 case GL_DEBUG_LOGGED_MESSAGES:
2453 *params = static_cast<GLint>(mDebug.getMessageCount());
2454 break;
2455 case GL_DEBUG_NEXT_LOGGED_MESSAGE_LENGTH:
2456 *params = static_cast<GLint>(mDebug.getNextMessageLength());
2457 break;
2458 case GL_DEBUG_GROUP_STACK_DEPTH:
2459 *params = static_cast<GLint>(mDebug.getGroupStackDepth());
2460 break;
2461 case GL_MULTISAMPLE_EXT:
2462 *params = static_cast<GLint>(mMultiSampling);
2463 break;
2464 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
2465 *params = static_cast<GLint>(mSampleAlphaToOne);
2466 break;
2467 case GL_COVERAGE_MODULATION_CHROMIUM:
2468 *params = static_cast<GLint>(mCoverageModulation);
2469 break;
2470 case GL_ATOMIC_COUNTER_BUFFER_BINDING:
2471 *params = mBoundBuffers[BufferBinding::AtomicCounter].id();
2472 break;
2473 case GL_SHADER_STORAGE_BUFFER_BINDING:
2474 *params = mBoundBuffers[BufferBinding::ShaderStorage].id();
2475 break;
2476 case GL_DISPATCH_INDIRECT_BUFFER_BINDING:
2477 *params = mBoundBuffers[BufferBinding::DispatchIndirect].id();
2478 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -07002479 case GL_ALPHA_TEST_FUNC:
2480 *params = ToGLenum(mGLES1State.mAlphaTestFunc);
2481 break;
Lingfeng Yang96310cd2018-03-28 11:56:28 -07002482 case GL_CLIENT_ACTIVE_TEXTURE:
2483 *params = mGLES1State.mClientActiveTexture + GL_TEXTURE0;
2484 break;
Lingfeng Yangd2488ab2018-04-04 09:25:48 -07002485 case GL_MATRIX_MODE:
2486 *params = ToGLenum(mGLES1State.mMatrixMode);
2487 break;
Lingfeng Yanga0cfa872018-05-30 21:12:17 -07002488 case GL_SHADE_MODEL:
2489 *params = ToGLenum(mGLES1State.mShadeModel);
2490 break;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -07002491 case GL_MODELVIEW_STACK_DEPTH:
2492 case GL_PROJECTION_STACK_DEPTH:
2493 case GL_TEXTURE_STACK_DEPTH:
2494 *params = mGLES1State.getCurrentMatrixStackDepth(pname);
2495 break;
2496 case GL_LOGIC_OP_MODE:
2497 *params = ToGLenum(mGLES1State.mLogicOp);
2498 break;
2499 case GL_BLEND_SRC:
2500 *params = mBlend.sourceBlendRGB;
2501 break;
2502 case GL_BLEND_DST:
2503 *params = mBlend.destBlendRGB;
2504 break;
2505 case GL_PERSPECTIVE_CORRECTION_HINT:
2506 case GL_POINT_SMOOTH_HINT:
2507 case GL_LINE_SMOOTH_HINT:
2508 case GL_FOG_HINT:
2509 *params = mGLES1State.getHint(pname);
2510 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002511 default:
2512 UNREACHABLE();
2513 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002514 }
Jamie Madille98b1b52018-03-08 09:47:23 -05002515
2516 return NoError();
Shannon Woods53a94a82014-06-24 15:20:36 -04002517}
2518
Lingfeng Yangabb09f12018-04-16 10:43:53 -07002519void State::getPointerv(const Context *context, GLenum pname, void **params) const
Geoff Lang70d0f492015-12-10 17:45:46 -05002520{
2521 switch (pname)
2522 {
2523 case GL_DEBUG_CALLBACK_FUNCTION:
2524 *params = reinterpret_cast<void *>(mDebug.getCallback());
2525 break;
2526 case GL_DEBUG_CALLBACK_USER_PARAM:
2527 *params = const_cast<void *>(mDebug.getUserParam());
2528 break;
Lingfeng Yangabb09f12018-04-16 10:43:53 -07002529 case GL_VERTEX_ARRAY_POINTER:
2530 case GL_NORMAL_ARRAY_POINTER:
2531 case GL_COLOR_ARRAY_POINTER:
2532 case GL_TEXTURE_COORD_ARRAY_POINTER:
2533 case GL_POINT_SIZE_ARRAY_POINTER_OES:
2534 QueryVertexAttribPointerv(getVertexArray()->getVertexAttribute(
2535 context->vertexArrayIndex(ParamToVertexArrayType(pname))),
2536 GL_VERTEX_ATTRIB_ARRAY_POINTER, params);
2537 return;
Geoff Lang70d0f492015-12-10 17:45:46 -05002538 default:
2539 UNREACHABLE();
2540 break;
2541 }
2542}
2543
Martin Radev66fb8202016-07-28 11:45:20 +03002544void State::getIntegeri_v(GLenum target, GLuint index, GLint *data)
Shannon Woods53a94a82014-06-24 15:20:36 -04002545{
2546 switch (target)
2547 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002548 case GL_TRANSFORM_FEEDBACK_BUFFER_BINDING:
2549 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2550 *data = mTransformFeedback->getIndexedBuffer(index).id();
2551 break;
2552 case GL_UNIFORM_BUFFER_BINDING:
2553 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2554 *data = mUniformBuffers[index].id();
2555 break;
2556 case GL_ATOMIC_COUNTER_BUFFER_BINDING:
2557 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2558 *data = mAtomicCounterBuffers[index].id();
2559 break;
2560 case GL_SHADER_STORAGE_BUFFER_BINDING:
2561 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2562 *data = mShaderStorageBuffers[index].id();
2563 break;
2564 case GL_VERTEX_BINDING_BUFFER:
2565 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2566 *data = mVertexArray->getVertexBinding(index).getBuffer().id();
2567 break;
2568 case GL_VERTEX_BINDING_DIVISOR:
2569 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2570 *data = mVertexArray->getVertexBinding(index).getDivisor();
2571 break;
2572 case GL_VERTEX_BINDING_OFFSET:
2573 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2574 *data = static_cast<GLuint>(mVertexArray->getVertexBinding(index).getOffset());
2575 break;
2576 case GL_VERTEX_BINDING_STRIDE:
2577 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2578 *data = mVertexArray->getVertexBinding(index).getStride();
2579 break;
2580 case GL_SAMPLE_MASK_VALUE:
2581 ASSERT(static_cast<size_t>(index) < mSampleMaskValues.size());
2582 *data = mSampleMaskValues[index];
2583 break;
2584 case GL_IMAGE_BINDING_NAME:
2585 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2586 *data = mImageUnits[index].texture.id();
2587 break;
2588 case GL_IMAGE_BINDING_LEVEL:
2589 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2590 *data = mImageUnits[index].level;
2591 break;
2592 case GL_IMAGE_BINDING_LAYER:
2593 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2594 *data = mImageUnits[index].layer;
2595 break;
2596 case GL_IMAGE_BINDING_ACCESS:
2597 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2598 *data = mImageUnits[index].access;
2599 break;
2600 case GL_IMAGE_BINDING_FORMAT:
2601 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2602 *data = mImageUnits[index].format;
2603 break;
2604 default:
2605 UNREACHABLE();
2606 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002607 }
Shannon Woods53a94a82014-06-24 15:20:36 -04002608}
2609
Martin Radev66fb8202016-07-28 11:45:20 +03002610void State::getInteger64i_v(GLenum target, GLuint index, GLint64 *data)
Shannon Woods53a94a82014-06-24 15:20:36 -04002611{
2612 switch (target)
2613 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002614 case GL_TRANSFORM_FEEDBACK_BUFFER_START:
2615 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2616 *data = mTransformFeedback->getIndexedBuffer(index).getOffset();
2617 break;
2618 case GL_TRANSFORM_FEEDBACK_BUFFER_SIZE:
2619 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2620 *data = mTransformFeedback->getIndexedBuffer(index).getSize();
2621 break;
2622 case GL_UNIFORM_BUFFER_START:
2623 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2624 *data = mUniformBuffers[index].getOffset();
2625 break;
2626 case GL_UNIFORM_BUFFER_SIZE:
2627 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2628 *data = mUniformBuffers[index].getSize();
2629 break;
2630 case GL_ATOMIC_COUNTER_BUFFER_START:
2631 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2632 *data = mAtomicCounterBuffers[index].getOffset();
2633 break;
2634 case GL_ATOMIC_COUNTER_BUFFER_SIZE:
2635 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2636 *data = mAtomicCounterBuffers[index].getSize();
2637 break;
2638 case GL_SHADER_STORAGE_BUFFER_START:
2639 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2640 *data = mShaderStorageBuffers[index].getOffset();
2641 break;
2642 case GL_SHADER_STORAGE_BUFFER_SIZE:
2643 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2644 *data = mShaderStorageBuffers[index].getSize();
2645 break;
2646 default:
2647 UNREACHABLE();
2648 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002649 }
Martin Radev66fb8202016-07-28 11:45:20 +03002650}
Shannon Woods53a94a82014-06-24 15:20:36 -04002651
Martin Radev66fb8202016-07-28 11:45:20 +03002652void State::getBooleani_v(GLenum target, GLuint index, GLboolean *data)
2653{
Xinghua Cao9c8e1a32017-12-06 17:59:58 +08002654 switch (target)
2655 {
2656 case GL_IMAGE_BINDING_LAYERED:
2657 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2658 *data = mImageUnits[index].layered;
2659 break;
2660 default:
2661 UNREACHABLE();
2662 break;
2663 }
Shannon Woods53a94a82014-06-24 15:20:36 -04002664}
2665
Jamie Madillbc918e72018-03-08 09:47:21 -05002666Error State::syncDirtyObjects(const Context *context, const DirtyObjects &bitset)
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002667{
Jiajia Qin5ae6ee42018-03-06 17:39:42 +08002668 const DirtyObjects &dirtyObjects = mDirtyObjects & bitset;
2669 for (auto dirtyObject : dirtyObjects)
Jamie Madillc9d442d2016-01-20 11:17:24 -05002670 {
2671 switch (dirtyObject)
2672 {
2673 case DIRTY_OBJECT_READ_FRAMEBUFFER:
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002674 ASSERT(mReadFramebuffer);
Jamie Madill19fa1c62018-03-08 09:47:21 -05002675 ANGLE_TRY(mReadFramebuffer->syncState(context));
Jamie Madillc9d442d2016-01-20 11:17:24 -05002676 break;
2677 case DIRTY_OBJECT_DRAW_FRAMEBUFFER:
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002678 ASSERT(mDrawFramebuffer);
Jamie Madill19fa1c62018-03-08 09:47:21 -05002679 ANGLE_TRY(mDrawFramebuffer->syncState(context));
Jamie Madillc9d442d2016-01-20 11:17:24 -05002680 break;
2681 case DIRTY_OBJECT_VERTEX_ARRAY:
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002682 ASSERT(mVertexArray);
Frank Henigman0af5b862018-03-27 20:19:33 -04002683 ANGLE_TRY(mVertexArray->syncState(context));
Jamie Madillc9d442d2016-01-20 11:17:24 -05002684 break;
Jamie Madille25b8002018-09-20 13:39:49 -04002685 case DIRTY_OBJECT_SAMPLERS:
2686 syncSamplers(context);
2687 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002688 case DIRTY_OBJECT_PROGRAM_TEXTURES:
Luc Ferron4bba74f2018-04-19 14:40:45 -04002689 ANGLE_TRY(syncProgramTextures(context));
Jamie Madill81c2e252017-09-09 23:32:46 -04002690 break;
Jamie Madill70aeda42018-08-20 12:17:40 -04002691 case DIRTY_OBJECT_PROGRAM:
2692 ANGLE_TRY(mProgram->syncState(context));
2693 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002694
Jamie Madillc9d442d2016-01-20 11:17:24 -05002695 default:
2696 UNREACHABLE();
2697 break;
2698 }
2699 }
2700
Jiajia Qin5ae6ee42018-03-06 17:39:42 +08002701 mDirtyObjects &= ~dirtyObjects;
Jamie Madillbc918e72018-03-08 09:47:21 -05002702 return NoError();
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002703}
2704
Jamie Madille25b8002018-09-20 13:39:49 -04002705void State::syncSamplers(const Context *context)
2706{
2707 if (mDirtySamplers.none())
2708 return;
2709
2710 // This could be optimized by tracking which samplers are dirty.
2711 for (size_t samplerIndex : mDirtySamplers)
2712 {
2713 BindingPointer<Sampler> &sampler = mSamplers[samplerIndex];
2714 if (sampler.get())
2715 {
2716 sampler->syncState(context);
2717 }
2718 }
2719
2720 mDirtySamplers.reset();
2721}
2722
Luc Ferron4bba74f2018-04-19 14:40:45 -04002723Error State::syncProgramTextures(const Context *context)
Jamie Madill81c2e252017-09-09 23:32:46 -04002724{
Jamie Madill81c2e252017-09-09 23:32:46 -04002725 // TODO(jmadill): Fine-grained updates.
2726 if (!mProgram)
2727 {
Luc Ferron4bba74f2018-04-19 14:40:45 -04002728 return NoError();
Jamie Madill81c2e252017-09-09 23:32:46 -04002729 }
2730
2731 ASSERT(mDirtyObjects[DIRTY_OBJECT_PROGRAM_TEXTURES]);
2732 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
2733
Jamie Madill0f80ed82017-09-19 00:24:56 -04002734 ActiveTextureMask newActiveTextures;
2735
Geoff Lange51ba632017-11-21 11:45:25 -05002736 // Initialize to the 'Initialized' state and set to 'MayNeedInit' if any texture is not
2737 // initialized.
2738 mCachedTexturesInitState = InitState::Initialized;
Qin Jiajia47f6dd02018-08-10 13:36:32 +08002739 mCachedImageTexturesInitState = InitState::Initialized;
Geoff Lange51ba632017-11-21 11:45:25 -05002740
Jamie Madill7e4eff12018-08-08 15:49:26 -04002741 const ActiveTextureMask &activeTextures = mProgram->getActiveSamplersMask();
2742 const ActiveTextureArray<TextureType> &textureTypes = mProgram->getActiveSamplerTypes();
2743
2744 for (size_t textureUnitIndex : activeTextures)
Jamie Madill81c2e252017-09-09 23:32:46 -04002745 {
Jamie Madill7e4eff12018-08-08 15:49:26 -04002746 TextureType textureType = textureTypes[textureUnitIndex];
Jamie Madill81c2e252017-09-09 23:32:46 -04002747
jchen1090f466a2018-08-13 15:05:25 +08002748 Texture *texture =
2749 getSamplerTexture(static_cast<unsigned int>(textureUnitIndex), textureType);
2750 Sampler *sampler = getSampler(static_cast<GLuint>(textureUnitIndex));
Jamie Madill4787d702018-08-08 15:49:26 -04002751 ASSERT(static_cast<size_t>(textureUnitIndex) < mActiveTexturesCache.size());
Jamie Madill7e4eff12018-08-08 15:49:26 -04002752 ASSERT(static_cast<size_t>(textureUnitIndex) < newActiveTextures.size());
2753
2754 ASSERT(texture);
2755
2756 // Mark the texture binding bit as dirty if the texture completeness changes.
2757 // TODO(jmadill): Use specific dirty bit for completeness change.
Jamie Madill38fe6842018-09-19 07:20:00 -04002758 if (texture->isSamplerComplete(context, sampler))
Jamie Madill81c2e252017-09-09 23:32:46 -04002759 {
Jamie Madillf668a4b2018-09-23 17:01:20 -04002760 if (texture->hasAnyDirtyBit())
2761 {
2762 ANGLE_TRY(texture->syncState(context));
2763 }
Jamie Madill4787d702018-08-08 15:49:26 -04002764 mActiveTexturesCache[textureUnitIndex] = texture;
Jamie Madill7e4eff12018-08-08 15:49:26 -04002765 }
2766 else
2767 {
Jamie Madill4787d702018-08-08 15:49:26 -04002768 mActiveTexturesCache[textureUnitIndex] = nullptr;
Jamie Madill7e4eff12018-08-08 15:49:26 -04002769 }
Jamie Madill81c2e252017-09-09 23:32:46 -04002770
Jamie Madill7e4eff12018-08-08 15:49:26 -04002771 // Bind the texture unconditionally, to recieve completeness change notifications.
Jamie Madillf668a4b2018-09-23 17:01:20 -04002772 mCompleteTextureBindings[textureUnitIndex].bind(texture->getImplementation());
Jamie Madill7e4eff12018-08-08 15:49:26 -04002773 newActiveTextures.set(textureUnitIndex);
Jamie Madill81c2e252017-09-09 23:32:46 -04002774
Jamie Madill7e4eff12018-08-08 15:49:26 -04002775 if (texture->initState() == InitState::MayNeedInit)
2776 {
2777 mCachedTexturesInitState = InitState::MayNeedInit;
Jamie Madill81c2e252017-09-09 23:32:46 -04002778 }
2779 }
Jamie Madill0f80ed82017-09-19 00:24:56 -04002780
2781 // Unset now missing textures.
Jamie Madill7e4eff12018-08-08 15:49:26 -04002782 ActiveTextureMask negativeMask = activeTextures & ~newActiveTextures;
Jamie Madill0f80ed82017-09-19 00:24:56 -04002783 if (negativeMask.any())
2784 {
2785 for (auto textureIndex : negativeMask)
2786 {
2787 mCompleteTextureBindings[textureIndex].reset();
Jamie Madill4787d702018-08-08 15:49:26 -04002788 mActiveTexturesCache[textureIndex] = nullptr;
Jamie Madill0f80ed82017-09-19 00:24:56 -04002789 }
2790 }
Luc Ferron4bba74f2018-04-19 14:40:45 -04002791
Qin Jiajia47f6dd02018-08-10 13:36:32 +08002792 for (size_t imageUnitIndex : mProgram->getActiveImagesMask())
2793 {
2794 Texture *texture = mImageUnits[imageUnitIndex].texture.get();
2795 if (!texture)
2796 {
2797 continue;
2798 }
Jamie Madillf668a4b2018-09-23 17:01:20 -04002799 if (texture->hasAnyDirtyBit())
2800 {
2801 ANGLE_TRY(texture->syncState(context));
2802 }
Qin Jiajia47f6dd02018-08-10 13:36:32 +08002803 if (texture->initState() == InitState::MayNeedInit)
2804 {
2805 mCachedImageTexturesInitState = InitState::MayNeedInit;
2806 }
2807 }
2808
Luc Ferron4bba74f2018-04-19 14:40:45 -04002809 return NoError();
Jamie Madill81c2e252017-09-09 23:32:46 -04002810}
2811
Jamie Madillbc918e72018-03-08 09:47:21 -05002812Error State::syncDirtyObject(const Context *context, GLenum target)
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002813{
2814 DirtyObjects localSet;
2815
2816 switch (target)
2817 {
2818 case GL_READ_FRAMEBUFFER:
2819 localSet.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2820 break;
2821 case GL_DRAW_FRAMEBUFFER:
2822 localSet.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2823 break;
2824 case GL_FRAMEBUFFER:
2825 localSet.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2826 localSet.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2827 break;
2828 case GL_VERTEX_ARRAY:
2829 localSet.set(DIRTY_OBJECT_VERTEX_ARRAY);
2830 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002831 case GL_TEXTURE:
Jamie Madille25b8002018-09-20 13:39:49 -04002832 localSet.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
2833 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002834 case GL_SAMPLER:
Jamie Madill70aeda42018-08-20 12:17:40 -04002835 localSet.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Jamie Madille25b8002018-09-20 13:39:49 -04002836 localSet.set(DIRTY_OBJECT_SAMPLERS);
Jamie Madill70aeda42018-08-20 12:17:40 -04002837 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002838 case GL_PROGRAM:
2839 localSet.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Jamie Madill70aeda42018-08-20 12:17:40 -04002840 localSet.set(DIRTY_OBJECT_PROGRAM);
Jamie Madill81c2e252017-09-09 23:32:46 -04002841 break;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002842 }
2843
Jamie Madillbc918e72018-03-08 09:47:21 -05002844 return syncDirtyObjects(context, localSet);
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002845}
2846
2847void State::setObjectDirty(GLenum target)
2848{
2849 switch (target)
2850 {
2851 case GL_READ_FRAMEBUFFER:
2852 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2853 break;
2854 case GL_DRAW_FRAMEBUFFER:
2855 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2856 break;
2857 case GL_FRAMEBUFFER:
2858 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2859 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2860 break;
2861 case GL_VERTEX_ARRAY:
2862 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
2863 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002864 case GL_TEXTURE:
Jamie Madill70aeda42018-08-20 12:17:40 -04002865 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
2866 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
2867 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002868 case GL_PROGRAM:
2869 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Jamie Madill70aeda42018-08-20 12:17:40 -04002870 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM);
Jamie Madill81c2e252017-09-09 23:32:46 -04002871 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
2872 break;
Jamie Madilla779b612017-07-24 11:46:05 -04002873 }
2874}
2875
2876void State::onProgramExecutableChange(Program *program)
2877{
2878 // OpenGL Spec:
2879 // "If LinkProgram or ProgramBinary successfully re-links a program object
2880 // that was already in use as a result of a previous call to UseProgram, then the
2881 // generated executable code will be installed as part of the current rendering state."
2882 if (program->isLinked() && mProgram == program)
2883 {
2884 mDirtyBits.set(DIRTY_BIT_PROGRAM_EXECUTABLE);
Jamie Madill81c2e252017-09-09 23:32:46 -04002885 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Jamie Madill70aeda42018-08-20 12:17:40 -04002886 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM);
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002887 }
Shannon Woods53a94a82014-06-24 15:20:36 -04002888}
Jamie Madillc9d442d2016-01-20 11:17:24 -05002889
Jamie Madille25b8002018-09-20 13:39:49 -04002890void State::setSamplerDirty(size_t samplerIndex)
2891{
2892 mDirtyObjects.set(DIRTY_OBJECT_SAMPLERS);
2893 mDirtySamplers.set(samplerIndex);
2894}
2895
Xinghua Cao65ec0b22017-03-28 16:10:52 +08002896void State::setImageUnit(const Context *context,
Will Harris63aa0e52018-09-05 16:15:46 -07002897 size_t unit,
Xinghua Cao65ec0b22017-03-28 16:10:52 +08002898 Texture *texture,
2899 GLint level,
2900 GLboolean layered,
2901 GLint layer,
2902 GLenum access,
2903 GLenum format)
2904{
2905 mImageUnits[unit].texture.set(context, texture);
2906 mImageUnits[unit].level = level;
2907 mImageUnits[unit].layered = layered;
2908 mImageUnits[unit].layer = layer;
2909 mImageUnits[unit].access = access;
2910 mImageUnits[unit].format = format;
jchen1099118c12018-09-10 16:28:51 +08002911 mDirtyBits.set(DIRTY_BIT_IMAGE_BINDINGS);
Xinghua Cao65ec0b22017-03-28 16:10:52 +08002912}
2913
Will Harris63aa0e52018-09-05 16:15:46 -07002914const ImageUnit &State::getImageUnit(size_t unit) const
Xinghua Cao65ec0b22017-03-28 16:10:52 +08002915{
2916 return mImageUnits[unit];
2917}
2918
Jamie Madill81c2e252017-09-09 23:32:46 -04002919// Handle a dirty texture event.
Jamie Madill6c43a012018-08-08 15:49:27 -04002920void State::onActiveTextureStateChange(size_t textureIndex)
Jamie Madill81c2e252017-09-09 23:32:46 -04002921{
2922 // Conservatively assume all textures are dirty.
2923 // TODO(jmadill): More fine-grained update.
2924 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Geoff Lange51ba632017-11-21 11:45:25 -05002925
Jamie Madill6c43a012018-08-08 15:49:27 -04002926 if (!mActiveTexturesCache[textureIndex] ||
2927 mActiveTexturesCache[textureIndex]->initState() == InitState::MayNeedInit)
Geoff Lange51ba632017-11-21 11:45:25 -05002928 {
2929 mCachedTexturesInitState = InitState::MayNeedInit;
2930 }
Jamie Madill81c2e252017-09-09 23:32:46 -04002931}
2932
Jamie Madill6d32cef2018-08-14 02:34:28 -04002933void State::onUniformBufferStateChange(size_t uniformBufferIndex)
2934{
2935 // This could be represented by a different dirty bit. Using the same one keeps it simple.
2936 mDirtyBits.set(DIRTY_BIT_UNIFORM_BUFFER_BINDINGS);
2937}
2938
Jamie Madill05b35b22017-10-03 09:01:44 -04002939Error State::clearUnclearedActiveTextures(const Context *context)
2940{
Jamie Madilla59fc192017-11-02 12:57:58 -04002941 ASSERT(mRobustResourceInit);
Geoff Lang9bf86f02018-07-26 11:46:34 -04002942 ASSERT(!mDirtyObjects[DIRTY_OBJECT_PROGRAM_TEXTURES]);
Geoff Langd4fff502017-09-22 11:28:28 -04002943
Jamie Madill7e4eff12018-08-08 15:49:26 -04002944 if (!mProgram)
2945 return NoError();
2946
Qin Jiajia47f6dd02018-08-10 13:36:32 +08002947 if (mCachedTexturesInitState != InitState::Initialized)
Jamie Madill05b35b22017-10-03 09:01:44 -04002948 {
Qin Jiajia47f6dd02018-08-10 13:36:32 +08002949 for (size_t textureUnitIndex : mProgram->getActiveSamplersMask())
Jamie Madill05b35b22017-10-03 09:01:44 -04002950 {
Qin Jiajia47f6dd02018-08-10 13:36:32 +08002951 Texture *texture = mActiveTexturesCache[textureUnitIndex];
2952 if (texture)
2953 {
2954 ANGLE_TRY(texture->ensureInitialized(context));
2955 }
Jamie Madill05b35b22017-10-03 09:01:44 -04002956 }
Qin Jiajia47f6dd02018-08-10 13:36:32 +08002957 mCachedTexturesInitState = InitState::Initialized;
Jamie Madill05b35b22017-10-03 09:01:44 -04002958 }
Qin Jiajia47f6dd02018-08-10 13:36:32 +08002959 if (mCachedImageTexturesInitState != InitState::Initialized)
2960 {
2961 for (size_t imageUnitIndex : mProgram->getActiveImagesMask())
2962 {
2963 Texture *texture = mImageUnits[imageUnitIndex].texture.get();
2964 if (texture)
2965 {
2966 ANGLE_TRY(texture->ensureInitialized(context));
2967 }
2968 }
2969 mCachedImageTexturesInitState = InitState::Initialized;
2970 }
Jamie Madill05b35b22017-10-03 09:01:44 -04002971 return NoError();
2972}
2973
Jamie Madillc67323a2017-11-02 23:11:41 -04002974AttributesMask State::getAndResetDirtyCurrentValues() const
2975{
2976 AttributesMask retVal = mDirtyCurrentValues;
2977 mDirtyCurrentValues.reset();
2978 return retVal;
2979}
2980
James Darpiniane8a93c62018-01-04 18:02:24 -08002981bool State::isCurrentTransformFeedback(const TransformFeedback *tf) const
2982{
2983 return tf == mTransformFeedback.get();
2984}
Jamie Madillc9d442d2016-01-20 11:17:24 -05002985} // namespace gl