blob: 6b5e28779ea036cfd16e6a82a90846594b8cac3f [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"
Shannon Woods53a94a82014-06-24 15:20:36 -040028
Corentin Wallezad3ae902018-03-09 13:40:42 -050029namespace gl
30{
31
Olli Etuahobbf1c102016-06-28 13:31:33 +030032namespace
33{
34
Corentin Wallezad3ae902018-03-09 13:40:42 -050035bool GetAlternativeQueryType(QueryType type, QueryType *alternativeType)
Olli Etuahobbf1c102016-06-28 13:31:33 +030036{
Corentin Wallezad3ae902018-03-09 13:40:42 -050037 switch (type)
38 {
39 case QueryType::AnySamples:
40 *alternativeType = QueryType::AnySamplesConservative;
41 return true;
42 case QueryType::AnySamplesConservative:
43 *alternativeType = QueryType::AnySamples;
44 return true;
45 default:
46 return false;
47 }
Olli Etuahobbf1c102016-06-28 13:31:33 +030048}
49
50} // anonymous namepace
51
James Darpiniane8a93c62018-01-04 18:02:24 -080052void UpdateBufferBinding(const Context *context,
53 BindingPointer<Buffer> *binding,
54 Buffer *buffer,
55 BufferBinding target)
56{
57 if (binding->get())
Jamie Madill7267aa62018-04-17 15:28:21 -040058 (*binding)->onBindingChanged(context, false, target);
James Darpiniane8a93c62018-01-04 18:02:24 -080059 binding->set(context, buffer);
60 if (binding->get())
Jamie Madill7267aa62018-04-17 15:28:21 -040061 (*binding)->onBindingChanged(context, true, target);
James Darpiniane8a93c62018-01-04 18:02:24 -080062}
63
64void UpdateBufferBinding(const Context *context,
65 OffsetBindingPointer<Buffer> *binding,
66 Buffer *buffer,
67 BufferBinding target,
68 GLintptr offset,
69 GLsizeiptr size)
70{
71 if (binding->get())
Jamie Madill7267aa62018-04-17 15:28:21 -040072 (*binding)->onBindingChanged(context, false, target);
James Darpiniane8a93c62018-01-04 18:02:24 -080073 binding->set(context, buffer, offset, size);
74 if (binding->get())
Jamie Madill7267aa62018-04-17 15:28:21 -040075 (*binding)->onBindingChanged(context, true, target);
James Darpiniane8a93c62018-01-04 18:02:24 -080076}
77
Shannon Woods53a94a82014-06-24 15:20:36 -040078State::State()
Jamie Madille79b1e12015-11-04 16:36:37 -050079 : mMaxDrawBuffers(0),
80 mMaxCombinedTextureImageUnits(0),
81 mDepthClearValue(0),
82 mStencilClearValue(0),
83 mScissorTest(false),
84 mSampleCoverage(false),
85 mSampleCoverageValue(0),
86 mSampleCoverageInvert(false),
Jiawei Shaodb342272017-09-27 10:21:45 +080087 mSampleMask(false),
88 mMaxSampleMaskWords(0),
Jamie Madille79b1e12015-11-04 16:36:37 -050089 mStencilRef(0),
90 mStencilBackRef(0),
91 mLineWidth(0),
92 mGenerateMipmapHint(GL_NONE),
93 mFragmentShaderDerivativeHint(GL_NONE),
Geoff Langf41a7152016-09-19 15:11:17 -040094 mBindGeneratesResource(true),
Geoff Langfeb8c682017-02-13 16:07:35 -050095 mClientArraysEnabled(true),
Jamie Madille79b1e12015-11-04 16:36:37 -050096 mNearZ(0),
97 mFarZ(0),
98 mReadFramebuffer(nullptr),
99 mDrawFramebuffer(nullptr),
100 mProgram(nullptr),
101 mVertexArray(nullptr),
102 mActiveSampler(0),
Sami Väisänen74c23472016-05-09 17:30:30 +0300103 mPrimitiveRestart(false),
104 mMultiSampling(false),
Geoff Lang1d2c41d2016-10-19 16:14:46 -0700105 mSampleAlphaToOne(false),
Jamie Madille08a1d32017-03-07 17:24:06 -0500106 mFramebufferSRGB(true),
Jamie Madillc43be722017-07-13 16:22:14 -0400107 mRobustResourceInit(false),
108 mProgramBinaryCacheEnabled(false)
Shannon Woods53a94a82014-06-24 15:20:36 -0400109{
Geoff Lang76b10c92014-09-05 16:28:14 -0400110}
111
Lingfeng Yang13b708f2018-03-21 12:14:10 -0700112State::~State()
113{
114}
Geoff Lang76b10c92014-09-05 16:28:14 -0400115
Jamie Madill4928b7c2017-06-20 12:57:39 -0400116void State::initialize(const Context *context,
Geoff Langf41a7152016-09-19 15:11:17 -0400117 bool debug,
Geoff Langfeb8c682017-02-13 16:07:35 -0500118 bool bindGeneratesResource,
Jamie Madille08a1d32017-03-07 17:24:06 -0500119 bool clientArraysEnabled,
Jamie Madillc43be722017-07-13 16:22:14 -0400120 bool robustResourceInit,
121 bool programBinaryCacheEnabled)
Geoff Lang76b10c92014-09-05 16:28:14 -0400122{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700123 const Caps &caps = context->getCaps();
124 const Extensions &extensions = context->getExtensions();
Geoff Lang4751aab2017-10-30 15:14:52 -0400125 const Extensions &nativeExtensions = context->getImplementation()->getNativeExtensions();
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700126 const Version &clientVersion = context->getClientVersion();
Jamie Madill4928b7c2017-06-20 12:57:39 -0400127
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700128 mMaxDrawBuffers = caps.maxDrawBuffers;
Shannon Woods2df6a602014-09-26 16:12:07 -0400129 mMaxCombinedTextureImageUnits = caps.maxCombinedTextureImageUnits;
Shannon Woods53a94a82014-06-24 15:20:36 -0400130
Jamie Madillf75ab352015-03-16 10:46:52 -0400131 setColorClearValue(0.0f, 0.0f, 0.0f, 0.0f);
Shannon Woods53a94a82014-06-24 15:20:36 -0400132
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700133 mDepthClearValue = 1.0f;
Shannon Woods53a94a82014-06-24 15:20:36 -0400134 mStencilClearValue = 0;
135
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700136 mScissorTest = false;
137 mScissor.x = 0;
138 mScissor.y = 0;
139 mScissor.width = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400140 mScissor.height = 0;
141
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700142 mBlendColor.red = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400143 mBlendColor.green = 0;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700144 mBlendColor.blue = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400145 mBlendColor.alpha = 0;
146
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700147 mStencilRef = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400148 mStencilBackRef = 0;
149
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700150 mSampleCoverage = false;
151 mSampleCoverageValue = 1.0f;
Shannon Woods53a94a82014-06-24 15:20:36 -0400152 mSampleCoverageInvert = false;
Jiawei Shaodb342272017-09-27 10:21:45 +0800153
154 mMaxSampleMaskWords = caps.maxSampleMaskWords;
155 mSampleMask = false;
156 mSampleMaskValues.fill(~GLbitfield(0));
157
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700158 mGenerateMipmapHint = GL_DONT_CARE;
Shannon Woods53a94a82014-06-24 15:20:36 -0400159 mFragmentShaderDerivativeHint = GL_DONT_CARE;
160
Geoff Langf41a7152016-09-19 15:11:17 -0400161 mBindGeneratesResource = bindGeneratesResource;
Geoff Langfeb8c682017-02-13 16:07:35 -0500162 mClientArraysEnabled = clientArraysEnabled;
Geoff Langf41a7152016-09-19 15:11:17 -0400163
Shannon Woods53a94a82014-06-24 15:20:36 -0400164 mLineWidth = 1.0f;
165
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700166 mViewport.x = 0;
167 mViewport.y = 0;
168 mViewport.width = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400169 mViewport.height = 0;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700170 mNearZ = 0.0f;
171 mFarZ = 1.0f;
Shannon Woods53a94a82014-06-24 15:20:36 -0400172
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700173 mBlend.colorMaskRed = true;
Shannon Woods53a94a82014-06-24 15:20:36 -0400174 mBlend.colorMaskGreen = true;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700175 mBlend.colorMaskBlue = true;
Shannon Woods53a94a82014-06-24 15:20:36 -0400176 mBlend.colorMaskAlpha = true;
177
Geoff Lang76b10c92014-09-05 16:28:14 -0400178 mActiveSampler = 0;
179
Shannon Woods23e05002014-09-22 19:07:27 -0400180 mVertexAttribCurrentValues.resize(caps.maxVertexAttributes);
Shannon Woods53a94a82014-06-24 15:20:36 -0400181
Brandon Jonesc405ae72017-12-06 14:15:03 -0800182 // Set all indexes in state attributes type mask to float (default)
183 for (int i = 0; i < MAX_VERTEX_ATTRIBS; i++)
184 {
185 mCurrentValuesTypeMask.setIndex(GL_FLOAT, i);
186 }
187
Geoff Lang4dc3af02016-11-18 14:09:27 -0500188 mUniformBuffers.resize(caps.maxUniformBufferBindings);
Shannon Woodsf3acaf92014-09-23 18:07:11 -0400189
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800190 mSamplerTextures[TextureType::_2D].resize(caps.maxCombinedTextureImageUnits);
191 mSamplerTextures[TextureType::CubeMap].resize(caps.maxCombinedTextureImageUnits);
Geoff Langeb66a6e2016-10-31 13:06:12 -0400192 if (clientVersion >= Version(3, 0))
Shannon Woods53a94a82014-06-24 15:20:36 -0400193 {
Geoff Lang76b10c92014-09-05 16:28:14 -0400194 // TODO: These could also be enabled via extension
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800195 mSamplerTextures[TextureType::_2DArray].resize(caps.maxCombinedTextureImageUnits);
196 mSamplerTextures[TextureType::_3D].resize(caps.maxCombinedTextureImageUnits);
Shannon Woods53a94a82014-06-24 15:20:36 -0400197 }
Geoff Lang3b573612016-10-31 14:08:10 -0400198 if (clientVersion >= Version(3, 1))
199 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800200 mSamplerTextures[TextureType::_2DMultisample].resize(caps.maxCombinedTextureImageUnits);
Jiajia Qin6eafb042016-12-27 17:04:07 +0800201
202 mAtomicCounterBuffers.resize(caps.maxAtomicCounterBufferBindings);
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800203 mShaderStorageBuffers.resize(caps.maxShaderStorageBufferBindings);
Xinghua Cao65ec0b22017-03-28 16:10:52 +0800204 mImageUnits.resize(caps.maxImageUnits);
Geoff Lang3b573612016-10-31 14:08:10 -0400205 }
Geoff Lang4751aab2017-10-30 15:14:52 -0400206 if (nativeExtensions.textureRectangle)
Corentin Wallez13c0dd42017-07-04 18:27:01 -0400207 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800208 mSamplerTextures[TextureType::Rectangle].resize(caps.maxCombinedTextureImageUnits);
Corentin Wallez13c0dd42017-07-04 18:27:01 -0400209 }
Geoff Lang4751aab2017-10-30 15:14:52 -0400210 if (nativeExtensions.eglImageExternal || nativeExtensions.eglStreamConsumerExternal)
Ian Ewellbda75592016-04-18 17:25:54 -0400211 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800212 mSamplerTextures[TextureType::External].resize(caps.maxCombinedTextureImageUnits);
Ian Ewellbda75592016-04-18 17:25:54 -0400213 }
Jamie Madill81c2e252017-09-09 23:32:46 -0400214 mCompleteTextureCache.resize(caps.maxCombinedTextureImageUnits, nullptr);
215 mCompleteTextureBindings.reserve(caps.maxCombinedTextureImageUnits);
Geoff Lange51ba632017-11-21 11:45:25 -0500216 mCachedTexturesInitState = InitState::MayNeedInit;
Jamie Madill81c2e252017-09-09 23:32:46 -0400217 for (uint32_t textureIndex = 0; textureIndex < caps.maxCombinedTextureImageUnits;
218 ++textureIndex)
219 {
Jamie Madilld4442552018-02-27 22:03:47 -0500220 mCompleteTextureBindings.emplace_back(this, textureIndex);
Jamie Madill81c2e252017-09-09 23:32:46 -0400221 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400222
Geoff Lang76b10c92014-09-05 16:28:14 -0400223 mSamplers.resize(caps.maxCombinedTextureImageUnits);
Shannon Woods53a94a82014-06-24 15:20:36 -0400224
Corentin Wallezad3ae902018-03-09 13:40:42 -0500225 for (QueryType type : angle::AllEnums<QueryType>())
226 {
227 mActiveQueries[type].set(context, nullptr);
228 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400229
Ian Ewell3ffd78b2016-01-22 16:09:42 -0500230 mProgram = nullptr;
Shannon Woods53a94a82014-06-24 15:20:36 -0400231
Ian Ewell3ffd78b2016-01-22 16:09:42 -0500232 mReadFramebuffer = nullptr;
233 mDrawFramebuffer = nullptr;
Jamie Madillb4b53c52015-02-03 15:22:48 -0500234
235 mPrimitiveRestart = false;
Geoff Lang70d0f492015-12-10 17:45:46 -0500236
237 mDebug.setOutputEnabled(debug);
238 mDebug.setMaxLoggedMessages(extensions.maxDebugLoggedMessages);
Sami Väisänen74c23472016-05-09 17:30:30 +0300239
Geoff Lang488130e2017-09-27 13:53:11 -0400240 mMultiSampling = true;
241 mSampleAlphaToOne = false;
Sami Väisänena797e062016-05-12 15:23:40 +0300242
243 mCoverageModulation = GL_NONE;
Sami Väisänene45e53b2016-05-25 10:36:04 +0300244
245 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixProj);
246 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixMV);
247 mPathStencilFunc = GL_ALWAYS;
248 mPathStencilRef = 0;
249 mPathStencilMask = std::numeric_limits<GLuint>::max();
Jamie Madille08a1d32017-03-07 17:24:06 -0500250
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700251 mRobustResourceInit = robustResourceInit;
Jamie Madillc43be722017-07-13 16:22:14 -0400252 mProgramBinaryCacheEnabled = programBinaryCacheEnabled;
Lingfeng Yangdbb9c532018-02-25 19:58:24 -0800253
254 // GLES1 emulation: Initialize state for GLES1 if version
255 // applies
256 if (clientVersion < Version(2, 0))
257 {
Lingfeng Yange547aac2018-04-05 09:39:20 -0700258 mGLES1State.initialize(context, this);
Lingfeng Yangdbb9c532018-02-25 19:58:24 -0800259 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400260}
261
Jamie Madill6c1f6712017-02-14 19:08:04 -0500262void State::reset(const Context *context)
Shannon Woods53a94a82014-06-24 15:20:36 -0400263{
Jamie Madill8693bdb2017-09-02 15:32:14 -0400264 for (auto &bindingVec : mSamplerTextures)
Shannon Woods53a94a82014-06-24 15:20:36 -0400265 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800266 for (size_t textureIdx = 0; textureIdx < bindingVec.size(); textureIdx++)
Shannon Woods53a94a82014-06-24 15:20:36 -0400267 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800268 bindingVec[textureIdx].set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400269 }
270 }
Geoff Lang76b10c92014-09-05 16:28:14 -0400271 for (size_t samplerIdx = 0; samplerIdx < mSamplers.size(); samplerIdx++)
272 {
Jamie Madill4928b7c2017-06-20 12:57:39 -0400273 mSamplers[samplerIdx].set(context, nullptr);
Geoff Lang76b10c92014-09-05 16:28:14 -0400274 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400275
Xinghua Cao65ec0b22017-03-28 16:10:52 +0800276 for (auto &imageUnit : mImageUnits)
277 {
278 imageUnit.texture.set(context, nullptr);
279 imageUnit.level = 0;
280 imageUnit.layered = false;
281 imageUnit.layer = 0;
282 imageUnit.access = GL_READ_ONLY;
283 imageUnit.format = GL_R32UI;
284 }
285
Jamie Madill4928b7c2017-06-20 12:57:39 -0400286 mRenderbuffer.set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400287
Corentin Wallez336129f2017-10-17 15:55:40 -0400288 for (auto type : angle::AllEnums<BufferBinding>())
289 {
James Darpiniane8a93c62018-01-04 18:02:24 -0800290 UpdateBufferBinding(context, &mBoundBuffers[type], nullptr, type);
Corentin Wallez336129f2017-10-17 15:55:40 -0400291 }
292
Geoff Lang7dd2e102014-11-10 15:19:26 -0500293 if (mProgram)
294 {
Jamie Madill6c1f6712017-02-14 19:08:04 -0500295 mProgram->release(context);
Geoff Lang7dd2e102014-11-10 15:19:26 -0500296 }
Yunchao Hed7297bf2017-04-19 15:27:10 +0800297 mProgram = nullptr;
Geoff Lang7dd2e102014-11-10 15:19:26 -0500298
Yunchao Hea336b902017-08-02 16:05:21 +0800299 mProgramPipeline.set(context, nullptr);
300
James Darpiniane8a93c62018-01-04 18:02:24 -0800301 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -0400302 mTransformFeedback->onBindingChanged(context, false);
Jamie Madill4928b7c2017-06-20 12:57:39 -0400303 mTransformFeedback.set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400304
Corentin Wallezad3ae902018-03-09 13:40:42 -0500305 for (QueryType type : angle::AllEnums<QueryType>())
Shannon Woods53a94a82014-06-24 15:20:36 -0400306 {
Corentin Wallezad3ae902018-03-09 13:40:42 -0500307 mActiveQueries[type].set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400308 }
309
Corentin Wallez336129f2017-10-17 15:55:40 -0400310 for (auto &buf : mUniformBuffers)
Shannon Woods53a94a82014-06-24 15:20:36 -0400311 {
James Darpiniane8a93c62018-01-04 18:02:24 -0800312 UpdateBufferBinding(context, &buf, nullptr, BufferBinding::Uniform);
Shannon Woods53a94a82014-06-24 15:20:36 -0400313 }
314
Jiajia Qin6eafb042016-12-27 17:04:07 +0800315 for (auto &buf : mAtomicCounterBuffers)
316 {
James Darpiniane8a93c62018-01-04 18:02:24 -0800317 UpdateBufferBinding(context, &buf, nullptr, BufferBinding::AtomicCounter);
Jiajia Qin6eafb042016-12-27 17:04:07 +0800318 }
319
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800320 for (auto &buf : mShaderStorageBuffers)
321 {
James Darpiniane8a93c62018-01-04 18:02:24 -0800322 UpdateBufferBinding(context, &buf, nullptr, BufferBinding::ShaderStorage);
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800323 }
324
Sami Väisänene45e53b2016-05-25 10:36:04 +0300325 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixProj);
326 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixMV);
327 mPathStencilFunc = GL_ALWAYS;
328 mPathStencilRef = 0;
329 mPathStencilMask = std::numeric_limits<GLuint>::max();
330
Jamie Madill1b94d432015-08-07 13:23:23 -0400331 // TODO(jmadill): Is this necessary?
332 setAllDirtyBits();
Shannon Woods53a94a82014-06-24 15:20:36 -0400333}
334
335const RasterizerState &State::getRasterizerState() const
336{
337 return mRasterizer;
338}
339
340const BlendState &State::getBlendState() const
341{
342 return mBlend;
343}
344
345const DepthStencilState &State::getDepthStencilState() const
346{
347 return mDepthStencil;
348}
349
Jamie Madillf75ab352015-03-16 10:46:52 -0400350void State::setColorClearValue(float red, float green, float blue, float alpha)
Shannon Woods53a94a82014-06-24 15:20:36 -0400351{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700352 mColorClearValue.red = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400353 mColorClearValue.green = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700354 mColorClearValue.blue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400355 mColorClearValue.alpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400356 mDirtyBits.set(DIRTY_BIT_CLEAR_COLOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400357}
358
Jamie Madillf75ab352015-03-16 10:46:52 -0400359void State::setDepthClearValue(float depth)
Shannon Woods53a94a82014-06-24 15:20:36 -0400360{
361 mDepthClearValue = depth;
Jamie Madill1b94d432015-08-07 13:23:23 -0400362 mDirtyBits.set(DIRTY_BIT_CLEAR_DEPTH);
Shannon Woods53a94a82014-06-24 15:20:36 -0400363}
364
Jamie Madillf75ab352015-03-16 10:46:52 -0400365void State::setStencilClearValue(int stencil)
Shannon Woods53a94a82014-06-24 15:20:36 -0400366{
367 mStencilClearValue = stencil;
Jamie Madill1b94d432015-08-07 13:23:23 -0400368 mDirtyBits.set(DIRTY_BIT_CLEAR_STENCIL);
Shannon Woods53a94a82014-06-24 15:20:36 -0400369}
370
Shannon Woods53a94a82014-06-24 15:20:36 -0400371void State::setColorMask(bool red, bool green, bool blue, bool alpha)
372{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700373 mBlend.colorMaskRed = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400374 mBlend.colorMaskGreen = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700375 mBlend.colorMaskBlue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400376 mBlend.colorMaskAlpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400377 mDirtyBits.set(DIRTY_BIT_COLOR_MASK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400378}
379
380void State::setDepthMask(bool mask)
381{
382 mDepthStencil.depthMask = mask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400383 mDirtyBits.set(DIRTY_BIT_DEPTH_MASK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400384}
385
386bool State::isRasterizerDiscardEnabled() const
387{
388 return mRasterizer.rasterizerDiscard;
389}
390
391void State::setRasterizerDiscard(bool enabled)
392{
393 mRasterizer.rasterizerDiscard = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400394 mDirtyBits.set(DIRTY_BIT_RASTERIZER_DISCARD_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400395}
396
397bool State::isCullFaceEnabled() const
398{
399 return mRasterizer.cullFace;
400}
401
402void State::setCullFace(bool enabled)
403{
404 mRasterizer.cullFace = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400405 mDirtyBits.set(DIRTY_BIT_CULL_FACE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400406}
407
Corentin Wallez2e568cf2017-09-18 17:05:22 -0400408void State::setCullMode(CullFaceMode mode)
Shannon Woods53a94a82014-06-24 15:20:36 -0400409{
410 mRasterizer.cullMode = mode;
Jamie Madill1b94d432015-08-07 13:23:23 -0400411 mDirtyBits.set(DIRTY_BIT_CULL_FACE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400412}
413
414void State::setFrontFace(GLenum front)
415{
416 mRasterizer.frontFace = front;
Jamie Madill1b94d432015-08-07 13:23:23 -0400417 mDirtyBits.set(DIRTY_BIT_FRONT_FACE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400418}
419
420bool State::isDepthTestEnabled() const
421{
422 return mDepthStencil.depthTest;
423}
424
425void State::setDepthTest(bool enabled)
426{
427 mDepthStencil.depthTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400428 mDirtyBits.set(DIRTY_BIT_DEPTH_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400429}
430
431void State::setDepthFunc(GLenum depthFunc)
432{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700433 mDepthStencil.depthFunc = depthFunc;
434 mDirtyBits.set(DIRTY_BIT_DEPTH_FUNC);
Shannon Woods53a94a82014-06-24 15:20:36 -0400435}
436
437void State::setDepthRange(float zNear, float zFar)
438{
439 mNearZ = zNear;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700440 mFarZ = zFar;
Jamie Madill1b94d432015-08-07 13:23:23 -0400441 mDirtyBits.set(DIRTY_BIT_DEPTH_RANGE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400442}
443
Geoff Langd42f5b82015-04-16 14:03:29 -0400444float State::getNearPlane() const
Shannon Woods53a94a82014-06-24 15:20:36 -0400445{
Geoff Langd42f5b82015-04-16 14:03:29 -0400446 return mNearZ;
447}
448
449float State::getFarPlane() const
450{
451 return mFarZ;
Shannon Woods53a94a82014-06-24 15:20:36 -0400452}
453
454bool State::isBlendEnabled() const
455{
456 return mBlend.blend;
457}
458
459void State::setBlend(bool enabled)
460{
461 mBlend.blend = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400462 mDirtyBits.set(DIRTY_BIT_BLEND_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400463}
464
465void State::setBlendFactors(GLenum sourceRGB, GLenum destRGB, GLenum sourceAlpha, GLenum destAlpha)
466{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700467 mBlend.sourceBlendRGB = sourceRGB;
468 mBlend.destBlendRGB = destRGB;
Shannon Woods53a94a82014-06-24 15:20:36 -0400469 mBlend.sourceBlendAlpha = sourceAlpha;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700470 mBlend.destBlendAlpha = destAlpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400471 mDirtyBits.set(DIRTY_BIT_BLEND_FUNCS);
Shannon Woods53a94a82014-06-24 15:20:36 -0400472}
473
474void State::setBlendColor(float red, float green, float blue, float alpha)
475{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700476 mBlendColor.red = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400477 mBlendColor.green = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700478 mBlendColor.blue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400479 mBlendColor.alpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400480 mDirtyBits.set(DIRTY_BIT_BLEND_COLOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400481}
482
483void State::setBlendEquation(GLenum rgbEquation, GLenum alphaEquation)
484{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700485 mBlend.blendEquationRGB = rgbEquation;
Shannon Woods53a94a82014-06-24 15:20:36 -0400486 mBlend.blendEquationAlpha = alphaEquation;
Jamie Madill1b94d432015-08-07 13:23:23 -0400487 mDirtyBits.set(DIRTY_BIT_BLEND_EQUATIONS);
Shannon Woods53a94a82014-06-24 15:20:36 -0400488}
489
490const ColorF &State::getBlendColor() const
491{
492 return mBlendColor;
493}
494
495bool State::isStencilTestEnabled() const
496{
497 return mDepthStencil.stencilTest;
498}
499
500void State::setStencilTest(bool enabled)
501{
502 mDepthStencil.stencilTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400503 mDirtyBits.set(DIRTY_BIT_STENCIL_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400504}
505
506void State::setStencilParams(GLenum stencilFunc, GLint stencilRef, GLuint stencilMask)
507{
508 mDepthStencil.stencilFunc = stencilFunc;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700509 mStencilRef = (stencilRef > 0) ? stencilRef : 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400510 mDepthStencil.stencilMask = stencilMask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400511 mDirtyBits.set(DIRTY_BIT_STENCIL_FUNCS_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400512}
513
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700514void State::setStencilBackParams(GLenum stencilBackFunc,
515 GLint stencilBackRef,
516 GLuint stencilBackMask)
Shannon Woods53a94a82014-06-24 15:20:36 -0400517{
518 mDepthStencil.stencilBackFunc = stencilBackFunc;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700519 mStencilBackRef = (stencilBackRef > 0) ? stencilBackRef : 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400520 mDepthStencil.stencilBackMask = stencilBackMask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400521 mDirtyBits.set(DIRTY_BIT_STENCIL_FUNCS_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400522}
523
524void State::setStencilWritemask(GLuint stencilWritemask)
525{
526 mDepthStencil.stencilWritemask = stencilWritemask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400527 mDirtyBits.set(DIRTY_BIT_STENCIL_WRITEMASK_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400528}
529
530void State::setStencilBackWritemask(GLuint stencilBackWritemask)
531{
532 mDepthStencil.stencilBackWritemask = stencilBackWritemask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400533 mDirtyBits.set(DIRTY_BIT_STENCIL_WRITEMASK_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400534}
535
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700536void State::setStencilOperations(GLenum stencilFail,
537 GLenum stencilPassDepthFail,
538 GLenum stencilPassDepthPass)
Shannon Woods53a94a82014-06-24 15:20:36 -0400539{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700540 mDepthStencil.stencilFail = stencilFail;
Shannon Woods53a94a82014-06-24 15:20:36 -0400541 mDepthStencil.stencilPassDepthFail = stencilPassDepthFail;
542 mDepthStencil.stencilPassDepthPass = stencilPassDepthPass;
Jamie Madill1b94d432015-08-07 13:23:23 -0400543 mDirtyBits.set(DIRTY_BIT_STENCIL_OPS_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400544}
545
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700546void State::setStencilBackOperations(GLenum stencilBackFail,
547 GLenum stencilBackPassDepthFail,
548 GLenum stencilBackPassDepthPass)
Shannon Woods53a94a82014-06-24 15:20:36 -0400549{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700550 mDepthStencil.stencilBackFail = stencilBackFail;
Shannon Woods53a94a82014-06-24 15:20:36 -0400551 mDepthStencil.stencilBackPassDepthFail = stencilBackPassDepthFail;
552 mDepthStencil.stencilBackPassDepthPass = stencilBackPassDepthPass;
Jamie Madill1b94d432015-08-07 13:23:23 -0400553 mDirtyBits.set(DIRTY_BIT_STENCIL_OPS_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400554}
555
556GLint State::getStencilRef() const
557{
558 return mStencilRef;
559}
560
561GLint State::getStencilBackRef() const
562{
563 return mStencilBackRef;
564}
565
566bool State::isPolygonOffsetFillEnabled() const
567{
568 return mRasterizer.polygonOffsetFill;
569}
570
571void State::setPolygonOffsetFill(bool enabled)
572{
Jamie Madill1b94d432015-08-07 13:23:23 -0400573 mRasterizer.polygonOffsetFill = enabled;
574 mDirtyBits.set(DIRTY_BIT_POLYGON_OFFSET_FILL_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400575}
576
577void State::setPolygonOffsetParams(GLfloat factor, GLfloat units)
578{
579 // An application can pass NaN values here, so handle this gracefully
580 mRasterizer.polygonOffsetFactor = factor != factor ? 0.0f : factor;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700581 mRasterizer.polygonOffsetUnits = units != units ? 0.0f : units;
Jamie Madill1b94d432015-08-07 13:23:23 -0400582 mDirtyBits.set(DIRTY_BIT_POLYGON_OFFSET);
Shannon Woods53a94a82014-06-24 15:20:36 -0400583}
584
585bool State::isSampleAlphaToCoverageEnabled() const
586{
587 return mBlend.sampleAlphaToCoverage;
588}
589
590void State::setSampleAlphaToCoverage(bool enabled)
591{
592 mBlend.sampleAlphaToCoverage = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400593 mDirtyBits.set(DIRTY_BIT_SAMPLE_ALPHA_TO_COVERAGE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400594}
595
596bool State::isSampleCoverageEnabled() const
597{
598 return mSampleCoverage;
599}
600
601void State::setSampleCoverage(bool enabled)
602{
603 mSampleCoverage = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400604 mDirtyBits.set(DIRTY_BIT_SAMPLE_COVERAGE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400605}
606
607void State::setSampleCoverageParams(GLclampf value, bool invert)
608{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700609 mSampleCoverageValue = value;
Shannon Woods53a94a82014-06-24 15:20:36 -0400610 mSampleCoverageInvert = invert;
Jamie Madill1b94d432015-08-07 13:23:23 -0400611 mDirtyBits.set(DIRTY_BIT_SAMPLE_COVERAGE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400612}
613
Geoff Lang0fbb6002015-04-16 11:11:53 -0400614GLclampf State::getSampleCoverageValue() const
Shannon Woods53a94a82014-06-24 15:20:36 -0400615{
Geoff Lang0fbb6002015-04-16 11:11:53 -0400616 return mSampleCoverageValue;
617}
Shannon Woods53a94a82014-06-24 15:20:36 -0400618
Geoff Lang0fbb6002015-04-16 11:11:53 -0400619bool State::getSampleCoverageInvert() const
620{
621 return mSampleCoverageInvert;
Shannon Woods53a94a82014-06-24 15:20:36 -0400622}
623
Jiawei Shaodb342272017-09-27 10:21:45 +0800624bool State::isSampleMaskEnabled() const
625{
626 return mSampleMask;
627}
628
629void State::setSampleMaskEnabled(bool enabled)
630{
631 mSampleMask = enabled;
632 mDirtyBits.set(DIRTY_BIT_SAMPLE_MASK_ENABLED);
633}
634
635void State::setSampleMaskParams(GLuint maskNumber, GLbitfield mask)
636{
637 ASSERT(maskNumber < mMaxSampleMaskWords);
638 mSampleMaskValues[maskNumber] = mask;
Jamie Madillc67323a2017-11-02 23:11:41 -0400639 // TODO(jmadill): Use a child dirty bit if we ever use more than two words.
640 mDirtyBits.set(DIRTY_BIT_SAMPLE_MASK);
Jiawei Shaodb342272017-09-27 10:21:45 +0800641}
642
643GLbitfield State::getSampleMaskWord(GLuint maskNumber) const
644{
645 ASSERT(maskNumber < mMaxSampleMaskWords);
646 return mSampleMaskValues[maskNumber];
647}
648
649GLuint State::getMaxSampleMaskWords() const
650{
651 return mMaxSampleMaskWords;
652}
653
Sami Väisänen74c23472016-05-09 17:30:30 +0300654void State::setSampleAlphaToOne(bool enabled)
655{
656 mSampleAlphaToOne = enabled;
657 mDirtyBits.set(DIRTY_BIT_SAMPLE_ALPHA_TO_ONE);
658}
659
660bool State::isSampleAlphaToOneEnabled() const
661{
662 return mSampleAlphaToOne;
663}
664
665void State::setMultisampling(bool enabled)
666{
667 mMultiSampling = enabled;
668 mDirtyBits.set(DIRTY_BIT_MULTISAMPLING);
669}
670
671bool State::isMultisamplingEnabled() const
672{
673 return mMultiSampling;
674}
675
Shannon Woods53a94a82014-06-24 15:20:36 -0400676bool State::isScissorTestEnabled() const
677{
678 return mScissorTest;
679}
680
681void State::setScissorTest(bool enabled)
682{
683 mScissorTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400684 mDirtyBits.set(DIRTY_BIT_SCISSOR_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400685}
686
687void State::setScissorParams(GLint x, GLint y, GLsizei width, GLsizei height)
688{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700689 mScissor.x = x;
690 mScissor.y = y;
691 mScissor.width = width;
Shannon Woods53a94a82014-06-24 15:20:36 -0400692 mScissor.height = height;
Jamie Madill1b94d432015-08-07 13:23:23 -0400693 mDirtyBits.set(DIRTY_BIT_SCISSOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400694}
695
696const Rectangle &State::getScissor() const
697{
698 return mScissor;
699}
700
701bool State::isDitherEnabled() const
702{
703 return mBlend.dither;
704}
705
706void State::setDither(bool enabled)
707{
708 mBlend.dither = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400709 mDirtyBits.set(DIRTY_BIT_DITHER_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400710}
711
Jamie Madillb4b53c52015-02-03 15:22:48 -0500712bool State::isPrimitiveRestartEnabled() const
713{
714 return mPrimitiveRestart;
715}
716
717void State::setPrimitiveRestart(bool enabled)
718{
719 mPrimitiveRestart = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400720 mDirtyBits.set(DIRTY_BIT_PRIMITIVE_RESTART_ENABLED);
Jamie Madillb4b53c52015-02-03 15:22:48 -0500721}
722
Shannon Woods53a94a82014-06-24 15:20:36 -0400723void State::setEnableFeature(GLenum feature, bool enabled)
724{
725 switch (feature)
726 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700727 case GL_MULTISAMPLE_EXT:
728 setMultisampling(enabled);
729 break;
730 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
731 setSampleAlphaToOne(enabled);
732 break;
733 case GL_CULL_FACE:
734 setCullFace(enabled);
735 break;
736 case GL_POLYGON_OFFSET_FILL:
737 setPolygonOffsetFill(enabled);
738 break;
739 case GL_SAMPLE_ALPHA_TO_COVERAGE:
740 setSampleAlphaToCoverage(enabled);
741 break;
742 case GL_SAMPLE_COVERAGE:
743 setSampleCoverage(enabled);
744 break;
745 case GL_SCISSOR_TEST:
746 setScissorTest(enabled);
747 break;
748 case GL_STENCIL_TEST:
749 setStencilTest(enabled);
750 break;
751 case GL_DEPTH_TEST:
752 setDepthTest(enabled);
753 break;
754 case GL_BLEND:
755 setBlend(enabled);
756 break;
757 case GL_DITHER:
758 setDither(enabled);
759 break;
760 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
761 setPrimitiveRestart(enabled);
762 break;
763 case GL_RASTERIZER_DISCARD:
764 setRasterizerDiscard(enabled);
765 break;
766 case GL_SAMPLE_MASK:
767 setSampleMaskEnabled(enabled);
768 break;
769 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
770 mDebug.setOutputSynchronous(enabled);
771 break;
772 case GL_DEBUG_OUTPUT:
773 mDebug.setOutputEnabled(enabled);
774 break;
775 case GL_FRAMEBUFFER_SRGB_EXT:
776 setFramebufferSRGB(enabled);
777 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -0700778
779 // GLES1 emulation
780 case GL_ALPHA_TEST:
781 mGLES1State.mAlphaTestEnabled = enabled;
782 break;
Lingfeng Yang23dc90b2018-04-23 09:01:49 -0700783 case GL_TEXTURE_2D:
784 mGLES1State.mTexUnitEnables[mActiveSampler].set(TextureType::_2D, enabled);
785 break;
786 case GL_TEXTURE_CUBE_MAP:
787 mGLES1State.mTexUnitEnables[mActiveSampler].set(TextureType::CubeMap, enabled);
788 break;
Lingfeng Yangd0febe72018-05-17 22:36:52 -0700789 case GL_LIGHTING:
790 mGLES1State.mLightingEnabled = enabled;
791 break;
792 case GL_LIGHT0:
793 case GL_LIGHT1:
794 case GL_LIGHT2:
795 case GL_LIGHT3:
796 case GL_LIGHT4:
797 case GL_LIGHT5:
798 case GL_LIGHT6:
799 case GL_LIGHT7:
800 mGLES1State.mLights[feature - GL_LIGHT0].enabled = enabled;
801 break;
802 case GL_NORMALIZE:
803 mGLES1State.mNormalizeEnabled = enabled;
804 break;
805 case GL_RESCALE_NORMAL:
806 mGLES1State.mRescaleNormalEnabled = enabled;
807 break;
808 case GL_COLOR_MATERIAL:
809 mGLES1State.mColorMaterialEnabled = enabled;
810 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700811 default:
812 UNREACHABLE();
Shannon Woods53a94a82014-06-24 15:20:36 -0400813 }
814}
815
Jamie Madilldfde6ab2016-06-09 07:07:18 -0700816bool State::getEnableFeature(GLenum feature) const
Shannon Woods53a94a82014-06-24 15:20:36 -0400817{
818 switch (feature)
819 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700820 case GL_MULTISAMPLE_EXT:
821 return isMultisamplingEnabled();
822 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
823 return isSampleAlphaToOneEnabled();
824 case GL_CULL_FACE:
825 return isCullFaceEnabled();
826 case GL_POLYGON_OFFSET_FILL:
827 return isPolygonOffsetFillEnabled();
828 case GL_SAMPLE_ALPHA_TO_COVERAGE:
829 return isSampleAlphaToCoverageEnabled();
830 case GL_SAMPLE_COVERAGE:
831 return isSampleCoverageEnabled();
832 case GL_SCISSOR_TEST:
833 return isScissorTestEnabled();
834 case GL_STENCIL_TEST:
835 return isStencilTestEnabled();
836 case GL_DEPTH_TEST:
837 return isDepthTestEnabled();
838 case GL_BLEND:
839 return isBlendEnabled();
840 case GL_DITHER:
841 return isDitherEnabled();
842 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
843 return isPrimitiveRestartEnabled();
844 case GL_RASTERIZER_DISCARD:
845 return isRasterizerDiscardEnabled();
846 case GL_SAMPLE_MASK:
847 return isSampleMaskEnabled();
848 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
849 return mDebug.isOutputSynchronous();
850 case GL_DEBUG_OUTPUT:
851 return mDebug.isOutputEnabled();
852 case GL_BIND_GENERATES_RESOURCE_CHROMIUM:
853 return isBindGeneratesResourceEnabled();
854 case GL_CLIENT_ARRAYS_ANGLE:
855 return areClientArraysEnabled();
856 case GL_FRAMEBUFFER_SRGB_EXT:
857 return getFramebufferSRGB();
858 case GL_ROBUST_RESOURCE_INITIALIZATION_ANGLE:
859 return mRobustResourceInit;
860 case GL_PROGRAM_CACHE_ENABLED_ANGLE:
861 return mProgramBinaryCacheEnabled;
Jamie Madillc43be722017-07-13 16:22:14 -0400862
Lingfeng Yang13b708f2018-03-21 12:14:10 -0700863 // GLES1 emulation
864 case GL_ALPHA_TEST:
865 return mGLES1State.mAlphaTestEnabled;
Lingfeng Yang01074432018-04-16 10:19:51 -0700866 case GL_VERTEX_ARRAY:
867 return mGLES1State.mVertexArrayEnabled;
868 case GL_NORMAL_ARRAY:
869 return mGLES1State.mNormalArrayEnabled;
870 case GL_COLOR_ARRAY:
871 return mGLES1State.mColorArrayEnabled;
872 case GL_POINT_SIZE_ARRAY_OES:
873 return mGLES1State.mPointSizeArrayEnabled;
874 case GL_TEXTURE_COORD_ARRAY:
875 return mGLES1State.mTexCoordArrayEnabled[mGLES1State.mClientActiveTexture];
Lingfeng Yang23dc90b2018-04-23 09:01:49 -0700876 case GL_TEXTURE_2D:
877 return mGLES1State.mTexUnitEnables[mActiveSampler].test(TextureType::_2D);
878 case GL_TEXTURE_CUBE_MAP:
879 return mGLES1State.mTexUnitEnables[mActiveSampler].test(TextureType::CubeMap);
Lingfeng Yangd0febe72018-05-17 22:36:52 -0700880 case GL_LIGHTING:
881 return mGLES1State.mLightingEnabled;
882 case GL_LIGHT0:
883 case GL_LIGHT1:
884 case GL_LIGHT2:
885 case GL_LIGHT3:
886 case GL_LIGHT4:
887 case GL_LIGHT5:
888 case GL_LIGHT6:
889 case GL_LIGHT7:
890 return mGLES1State.mLights[feature - GL_LIGHT0].enabled;
891 case GL_NORMALIZE:
892 return mGLES1State.mNormalizeEnabled;
893 case GL_RESCALE_NORMAL:
894 return mGLES1State.mRescaleNormalEnabled;
895 case GL_COLOR_MATERIAL:
896 return mGLES1State.mColorMaterialEnabled;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700897 default:
898 UNREACHABLE();
899 return false;
Shannon Woods53a94a82014-06-24 15:20:36 -0400900 }
901}
902
903void State::setLineWidth(GLfloat width)
904{
905 mLineWidth = width;
Jamie Madill1b94d432015-08-07 13:23:23 -0400906 mDirtyBits.set(DIRTY_BIT_LINE_WIDTH);
Shannon Woods53a94a82014-06-24 15:20:36 -0400907}
908
Geoff Lang4b3f4162015-04-16 13:22:05 -0400909float State::getLineWidth() const
910{
911 return mLineWidth;
912}
913
Shannon Woods53a94a82014-06-24 15:20:36 -0400914void State::setGenerateMipmapHint(GLenum hint)
915{
916 mGenerateMipmapHint = hint;
Jamie Madill1b94d432015-08-07 13:23:23 -0400917 mDirtyBits.set(DIRTY_BIT_GENERATE_MIPMAP_HINT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400918}
919
920void State::setFragmentShaderDerivativeHint(GLenum hint)
921{
922 mFragmentShaderDerivativeHint = hint;
Jamie Madill1b94d432015-08-07 13:23:23 -0400923 mDirtyBits.set(DIRTY_BIT_SHADER_DERIVATIVE_HINT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400924 // TODO: Propagate the hint to shader translator so we can write
925 // ddx, ddx_coarse, or ddx_fine depending on the hint.
926 // Ignore for now. It is valid for implementations to ignore hint.
927}
928
Geoff Langf41a7152016-09-19 15:11:17 -0400929bool State::isBindGeneratesResourceEnabled() const
930{
931 return mBindGeneratesResource;
932}
933
Geoff Langfeb8c682017-02-13 16:07:35 -0500934bool State::areClientArraysEnabled() const
935{
936 return mClientArraysEnabled;
937}
938
Shannon Woods53a94a82014-06-24 15:20:36 -0400939void State::setViewportParams(GLint x, GLint y, GLsizei width, GLsizei height)
940{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700941 mViewport.x = x;
942 mViewport.y = y;
943 mViewport.width = width;
Shannon Woods53a94a82014-06-24 15:20:36 -0400944 mViewport.height = height;
Jamie Madill1b94d432015-08-07 13:23:23 -0400945 mDirtyBits.set(DIRTY_BIT_VIEWPORT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400946}
947
948const Rectangle &State::getViewport() const
949{
950 return mViewport;
951}
952
953void State::setActiveSampler(unsigned int active)
954{
955 mActiveSampler = active;
956}
957
958unsigned int State::getActiveSampler() const
959{
Cooper Partin4d61f7e2015-08-12 10:56:50 -0700960 return static_cast<unsigned int>(mActiveSampler);
Shannon Woods53a94a82014-06-24 15:20:36 -0400961}
962
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800963void State::setSamplerTexture(const Context *context, TextureType type, Texture *texture)
Shannon Woods53a94a82014-06-24 15:20:36 -0400964{
Jamie Madill4928b7c2017-06-20 12:57:39 -0400965 mSamplerTextures[type][mActiveSampler].set(context, texture);
Jamie Madill81c2e252017-09-09 23:32:46 -0400966 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
967 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Shannon Woods53a94a82014-06-24 15:20:36 -0400968}
969
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800970Texture *State::getTargetTexture(TextureType type) const
Jamie Madillc29968b2016-01-20 11:17:23 -0500971{
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800972 return getSamplerTexture(static_cast<unsigned int>(mActiveSampler), type);
Jamie Madillc29968b2016-01-20 11:17:23 -0500973}
974
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800975Texture *State::getSamplerTexture(unsigned int sampler, TextureType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -0400976{
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800977 ASSERT(sampler < mSamplerTextures[type].size());
978 return mSamplerTextures[type][sampler].get();
Shannon Woods53a94a82014-06-24 15:20:36 -0400979}
980
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800981GLuint State::getSamplerTextureId(unsigned int sampler, TextureType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -0400982{
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800983 ASSERT(sampler < mSamplerTextures[type].size());
984 return mSamplerTextures[type][sampler].id();
Shannon Woods53a94a82014-06-24 15:20:36 -0400985}
986
Jamie Madilla02315b2017-02-23 14:14:47 -0500987void State::detachTexture(const Context *context, const TextureMap &zeroTextures, GLuint texture)
Shannon Woods53a94a82014-06-24 15:20:36 -0400988{
989 // Textures have a detach method on State rather than a simple
990 // removeBinding, because the zero/null texture objects are managed
991 // separately, and don't have to go through the Context's maps or
992 // the ResourceManager.
993
994 // [OpenGL ES 2.0.24] section 3.8 page 84:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700995 // If a texture object is deleted, it is as if all texture units which are bound to that texture
996 // object are rebound to texture object zero
Shannon Woods53a94a82014-06-24 15:20:36 -0400997
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800998 for (TextureType type : angle::AllEnums<TextureType>())
Shannon Woods53a94a82014-06-24 15:20:36 -0400999 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001000 TextureBindingVector &textureVector = mSamplerTextures[type];
Jamie Madill81c2e252017-09-09 23:32:46 -04001001 for (BindingPointer<Texture> &binding : textureVector)
Shannon Woods53a94a82014-06-24 15:20:36 -04001002 {
Geoff Lang76b10c92014-09-05 16:28:14 -04001003 if (binding.id() == texture)
Shannon Woods53a94a82014-06-24 15:20:36 -04001004 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001005 Texture *zeroTexture = zeroTextures[type].get();
1006 ASSERT(zeroTexture != nullptr);
Jamie Madille6382c32014-11-07 15:05:26 -05001007 // Zero textures are the "default" textures instead of NULL
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001008 binding.set(context, zeroTexture);
Jamie Madill81c2e252017-09-09 23:32:46 -04001009 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
Shannon Woods53a94a82014-06-24 15:20:36 -04001010 }
1011 }
1012 }
1013
Xinghua Cao65ec0b22017-03-28 16:10:52 +08001014 for (auto &bindingImageUnit : mImageUnits)
1015 {
1016 if (bindingImageUnit.texture.id() == texture)
1017 {
1018 bindingImageUnit.texture.set(context, nullptr);
1019 bindingImageUnit.level = 0;
1020 bindingImageUnit.layered = false;
1021 bindingImageUnit.layer = 0;
1022 bindingImageUnit.access = GL_READ_ONLY;
1023 bindingImageUnit.format = GL_R32UI;
1024 break;
1025 }
1026 }
1027
Shannon Woods53a94a82014-06-24 15:20:36 -04001028 // [OpenGL ES 2.0.24] section 4.4 page 112:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001029 // If a texture object is deleted while its image is attached to the currently bound
1030 // framebuffer, then it is as if Texture2DAttachment had been called, with a texture of 0, for
1031 // each attachment point to which this image was attached in the currently bound framebuffer.
Shannon Woods53a94a82014-06-24 15:20:36 -04001032
Jamie Madill8693bdb2017-09-02 15:32:14 -04001033 if (mReadFramebuffer && mReadFramebuffer->detachTexture(context, texture))
Shannon Woods53a94a82014-06-24 15:20:36 -04001034 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001035 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
Shannon Woods53a94a82014-06-24 15:20:36 -04001036 }
1037
Jamie Madill8693bdb2017-09-02 15:32:14 -04001038 if (mDrawFramebuffer && mDrawFramebuffer->detachTexture(context, texture))
Shannon Woods53a94a82014-06-24 15:20:36 -04001039 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001040 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
Shannon Woods53a94a82014-06-24 15:20:36 -04001041 }
1042}
1043
Jamie Madill4928b7c2017-06-20 12:57:39 -04001044void State::initializeZeroTextures(const Context *context, const TextureMap &zeroTextures)
Jamie Madille6382c32014-11-07 15:05:26 -05001045{
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001046 for (TextureType type : angle::AllEnums<TextureType>())
Jamie Madille6382c32014-11-07 15:05:26 -05001047 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001048 for (size_t textureUnit = 0; textureUnit < mSamplerTextures[type].size(); ++textureUnit)
Jamie Madille6382c32014-11-07 15:05:26 -05001049 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001050 mSamplerTextures[type][textureUnit].set(context, zeroTextures[type].get());
Jamie Madille6382c32014-11-07 15:05:26 -05001051 }
1052 }
1053}
1054
Jamie Madill4928b7c2017-06-20 12:57:39 -04001055void State::setSamplerBinding(const Context *context, GLuint textureUnit, Sampler *sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001056{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001057 mSamplers[textureUnit].set(context, sampler);
Jamie Madill81c2e252017-09-09 23:32:46 -04001058 mDirtyBits.set(DIRTY_BIT_SAMPLER_BINDINGS);
1059 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Shannon Woods53a94a82014-06-24 15:20:36 -04001060}
1061
1062GLuint State::getSamplerId(GLuint textureUnit) const
1063{
Geoff Lang76b10c92014-09-05 16:28:14 -04001064 ASSERT(textureUnit < mSamplers.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001065 return mSamplers[textureUnit].id();
1066}
1067
1068Sampler *State::getSampler(GLuint textureUnit) const
1069{
1070 return mSamplers[textureUnit].get();
1071}
1072
Jamie Madill4928b7c2017-06-20 12:57:39 -04001073void State::detachSampler(const Context *context, GLuint sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001074{
1075 // [OpenGL ES 3.0.2] section 3.8.2 pages 123-124:
1076 // If a sampler object that is currently bound to one or more texture units is
1077 // deleted, it is as though BindSampler is called once for each texture unit to
1078 // which the sampler is bound, with unit set to the texture unit and sampler set to zero.
Jamie Madill81c2e252017-09-09 23:32:46 -04001079 for (BindingPointer<Sampler> &samplerBinding : mSamplers)
Shannon Woods53a94a82014-06-24 15:20:36 -04001080 {
Geoff Lang76b10c92014-09-05 16:28:14 -04001081 if (samplerBinding.id() == sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001082 {
Jamie Madill4928b7c2017-06-20 12:57:39 -04001083 samplerBinding.set(context, nullptr);
Jamie Madill81c2e252017-09-09 23:32:46 -04001084 mDirtyBits.set(DIRTY_BIT_SAMPLER_BINDINGS);
Shannon Woods53a94a82014-06-24 15:20:36 -04001085 }
1086 }
1087}
1088
Jamie Madill4928b7c2017-06-20 12:57:39 -04001089void State::setRenderbufferBinding(const Context *context, Renderbuffer *renderbuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001090{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001091 mRenderbuffer.set(context, renderbuffer);
Jamie Madill8693bdb2017-09-02 15:32:14 -04001092 mDirtyBits.set(DIRTY_BIT_RENDERBUFFER_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001093}
1094
1095GLuint State::getRenderbufferId() const
1096{
1097 return mRenderbuffer.id();
1098}
1099
Jamie Madilldfde6ab2016-06-09 07:07:18 -07001100Renderbuffer *State::getCurrentRenderbuffer() const
Shannon Woods53a94a82014-06-24 15:20:36 -04001101{
1102 return mRenderbuffer.get();
1103}
1104
Jamie Madilla02315b2017-02-23 14:14:47 -05001105void State::detachRenderbuffer(const Context *context, GLuint renderbuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001106{
1107 // [OpenGL ES 2.0.24] section 4.4 page 109:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001108 // If a renderbuffer that is currently bound to RENDERBUFFER is deleted, it is as though
1109 // BindRenderbuffer had been executed with the target RENDERBUFFER and name of zero.
Shannon Woods53a94a82014-06-24 15:20:36 -04001110
1111 if (mRenderbuffer.id() == renderbuffer)
1112 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001113 setRenderbufferBinding(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001114 }
1115
1116 // [OpenGL ES 2.0.24] section 4.4 page 111:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001117 // If a renderbuffer object is deleted while its image is attached to the currently bound
1118 // framebuffer, then it is as if FramebufferRenderbuffer had been called, with a renderbuffer of
1119 // 0, for each attachment point to which this image was attached in the currently bound
1120 // framebuffer.
Shannon Woods53a94a82014-06-24 15:20:36 -04001121
1122 Framebuffer *readFramebuffer = mReadFramebuffer;
1123 Framebuffer *drawFramebuffer = mDrawFramebuffer;
1124
Jamie Madill8693bdb2017-09-02 15:32:14 -04001125 if (readFramebuffer && readFramebuffer->detachRenderbuffer(context, renderbuffer))
Shannon Woods53a94a82014-06-24 15:20:36 -04001126 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001127 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
Shannon Woods53a94a82014-06-24 15:20:36 -04001128 }
1129
1130 if (drawFramebuffer && drawFramebuffer != readFramebuffer)
1131 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001132 if (drawFramebuffer->detachRenderbuffer(context, renderbuffer))
1133 {
1134 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
1135 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001136 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001137}
1138
1139void State::setReadFramebufferBinding(Framebuffer *framebuffer)
1140{
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001141 if (mReadFramebuffer == framebuffer)
1142 return;
1143
Shannon Woods53a94a82014-06-24 15:20:36 -04001144 mReadFramebuffer = framebuffer;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001145 mDirtyBits.set(DIRTY_BIT_READ_FRAMEBUFFER_BINDING);
1146
1147 if (mReadFramebuffer && mReadFramebuffer->hasAnyDirtyBit())
1148 {
1149 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
1150 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001151}
1152
1153void State::setDrawFramebufferBinding(Framebuffer *framebuffer)
1154{
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001155 if (mDrawFramebuffer == framebuffer)
1156 return;
1157
Shannon Woods53a94a82014-06-24 15:20:36 -04001158 mDrawFramebuffer = framebuffer;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001159 mDirtyBits.set(DIRTY_BIT_DRAW_FRAMEBUFFER_BINDING);
1160
1161 if (mDrawFramebuffer && mDrawFramebuffer->hasAnyDirtyBit())
1162 {
1163 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
1164 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001165}
1166
1167Framebuffer *State::getTargetFramebuffer(GLenum target) const
1168{
1169 switch (target)
1170 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001171 case GL_READ_FRAMEBUFFER_ANGLE:
1172 return mReadFramebuffer;
1173 case GL_DRAW_FRAMEBUFFER_ANGLE:
1174 case GL_FRAMEBUFFER:
1175 return mDrawFramebuffer;
1176 default:
1177 UNREACHABLE();
Yunchao Hef81ce4a2017-04-24 10:49:17 +08001178 return nullptr;
Shannon Woods53a94a82014-06-24 15:20:36 -04001179 }
1180}
1181
Jamie Madill51f40ec2016-06-15 14:06:00 -04001182Framebuffer *State::getReadFramebuffer() const
Shannon Woods53a94a82014-06-24 15:20:36 -04001183{
1184 return mReadFramebuffer;
1185}
1186
Shannon Woods53a94a82014-06-24 15:20:36 -04001187bool State::removeReadFramebufferBinding(GLuint framebuffer)
1188{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001189 if (mReadFramebuffer != nullptr && mReadFramebuffer->id() == framebuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001190 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001191 setReadFramebufferBinding(nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001192 return true;
1193 }
1194
1195 return false;
1196}
1197
1198bool State::removeDrawFramebufferBinding(GLuint framebuffer)
1199{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001200 if (mReadFramebuffer != nullptr && mDrawFramebuffer->id() == framebuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001201 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001202 setDrawFramebufferBinding(nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001203 return true;
1204 }
1205
1206 return false;
1207}
1208
Jamie Madill7267aa62018-04-17 15:28:21 -04001209void State::setVertexArrayBinding(const Context *context, VertexArray *vertexArray)
Shannon Woods53a94a82014-06-24 15:20:36 -04001210{
James Darpiniane8a93c62018-01-04 18:02:24 -08001211 if (mVertexArray == vertexArray)
1212 return;
1213 if (mVertexArray)
Jamie Madill7267aa62018-04-17 15:28:21 -04001214 mVertexArray->onBindingChanged(context, false);
Shannon Woods53a94a82014-06-24 15:20:36 -04001215 mVertexArray = vertexArray;
James Darpiniane8a93c62018-01-04 18:02:24 -08001216 if (vertexArray)
Jamie Madill7267aa62018-04-17 15:28:21 -04001217 vertexArray->onBindingChanged(context, true);
Jamie Madill0b9e9032015-08-17 11:51:52 +00001218 mDirtyBits.set(DIRTY_BIT_VERTEX_ARRAY_BINDING);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001219
1220 if (mVertexArray && mVertexArray->hasAnyDirtyBit())
1221 {
1222 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1223 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001224}
1225
1226GLuint State::getVertexArrayId() const
1227{
Yunchao He4f285442017-04-21 12:15:49 +08001228 ASSERT(mVertexArray != nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001229 return mVertexArray->id();
1230}
1231
Jamie Madill7267aa62018-04-17 15:28:21 -04001232bool State::removeVertexArrayBinding(const Context *context, GLuint vertexArray)
Shannon Woods53a94a82014-06-24 15:20:36 -04001233{
James Darpiniane8a93c62018-01-04 18:02:24 -08001234 if (mVertexArray && mVertexArray->id() == vertexArray)
Shannon Woods53a94a82014-06-24 15:20:36 -04001235 {
Jamie Madill7267aa62018-04-17 15:28:21 -04001236 mVertexArray->onBindingChanged(context, false);
Yunchao Hed7297bf2017-04-19 15:27:10 +08001237 mVertexArray = nullptr;
Jamie Madill0b9e9032015-08-17 11:51:52 +00001238 mDirtyBits.set(DIRTY_BIT_VERTEX_ARRAY_BINDING);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001239 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001240 return true;
1241 }
1242
1243 return false;
1244}
1245
Jamie Madill4928b7c2017-06-20 12:57:39 -04001246void State::bindVertexBuffer(const Context *context,
1247 GLuint bindingIndex,
Shao80957d92017-02-20 21:25:59 +08001248 Buffer *boundBuffer,
1249 GLintptr offset,
1250 GLsizei stride)
1251{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001252 getVertexArray()->bindVertexBuffer(context, bindingIndex, boundBuffer, offset, stride);
Shao80957d92017-02-20 21:25:59 +08001253 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1254}
1255
Shaodde78e82017-05-22 14:13:27 +08001256void State::setVertexAttribBinding(const Context *context, GLuint attribIndex, GLuint bindingIndex)
Shao80957d92017-02-20 21:25:59 +08001257{
Shaodde78e82017-05-22 14:13:27 +08001258 getVertexArray()->setVertexAttribBinding(context, attribIndex, bindingIndex);
Shao80957d92017-02-20 21:25:59 +08001259 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1260}
1261
1262void State::setVertexAttribFormat(GLuint attribIndex,
1263 GLint size,
1264 GLenum type,
1265 bool normalized,
1266 bool pureInteger,
1267 GLuint relativeOffset)
1268{
1269 getVertexArray()->setVertexAttribFormat(attribIndex, size, type, normalized, pureInteger,
1270 relativeOffset);
1271 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1272}
1273
1274void State::setVertexBindingDivisor(GLuint bindingIndex, GLuint divisor)
1275{
1276 getVertexArray()->setVertexBindingDivisor(bindingIndex, divisor);
1277 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1278}
1279
Jamie Madill6c1f6712017-02-14 19:08:04 -05001280void State::setProgram(const Context *context, Program *newProgram)
Shannon Woods53a94a82014-06-24 15:20:36 -04001281{
Geoff Lang7dd2e102014-11-10 15:19:26 -05001282 if (mProgram != newProgram)
Shannon Woods53a94a82014-06-24 15:20:36 -04001283 {
Geoff Lang7dd2e102014-11-10 15:19:26 -05001284 if (mProgram)
1285 {
Jamie Madill6c1f6712017-02-14 19:08:04 -05001286 mProgram->release(context);
Geoff Lang7dd2e102014-11-10 15:19:26 -05001287 }
1288
1289 mProgram = newProgram;
1290
1291 if (mProgram)
1292 {
1293 newProgram->addRef();
Jamie Madill81c2e252017-09-09 23:32:46 -04001294 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Geoff Lang7dd2e102014-11-10 15:19:26 -05001295 }
Jamie Madilla779b612017-07-24 11:46:05 -04001296 mDirtyBits.set(DIRTY_BIT_PROGRAM_EXECUTABLE);
1297 mDirtyBits.set(DIRTY_BIT_PROGRAM_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001298 }
1299}
1300
Jamie Madill4928b7c2017-06-20 12:57:39 -04001301void State::setTransformFeedbackBinding(const Context *context,
1302 TransformFeedback *transformFeedback)
Shannon Woods53a94a82014-06-24 15:20:36 -04001303{
James Darpiniane8a93c62018-01-04 18:02:24 -08001304 if (transformFeedback == mTransformFeedback.get())
1305 return;
1306 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -04001307 mTransformFeedback->onBindingChanged(context, false);
Jamie Madill4928b7c2017-06-20 12:57:39 -04001308 mTransformFeedback.set(context, transformFeedback);
James Darpiniane8a93c62018-01-04 18:02:24 -08001309 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -04001310 mTransformFeedback->onBindingChanged(context, true);
Geoff Langded79232017-11-28 15:21:11 -05001311 mDirtyBits.set(DIRTY_BIT_TRANSFORM_FEEDBACK_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001312}
1313
Gregoire Payen de La Garanderie52742022015-02-04 14:55:39 +00001314bool State::isTransformFeedbackActiveUnpaused() const
1315{
Jamie Madill4166f012018-05-31 14:53:30 -04001316 TransformFeedback *curTransformFeedback = mTransformFeedback.get();
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001317 return curTransformFeedback && curTransformFeedback->isActive() &&
1318 !curTransformFeedback->isPaused();
Gregoire Payen de La Garanderie52742022015-02-04 14:55:39 +00001319}
1320
Jamie Madill4928b7c2017-06-20 12:57:39 -04001321bool State::removeTransformFeedbackBinding(const Context *context, GLuint transformFeedback)
Shannon Woods53a94a82014-06-24 15:20:36 -04001322{
1323 if (mTransformFeedback.id() == transformFeedback)
1324 {
James Darpiniane8a93c62018-01-04 18:02:24 -08001325 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -04001326 mTransformFeedback->onBindingChanged(context, false);
Jamie Madill4928b7c2017-06-20 12:57:39 -04001327 mTransformFeedback.set(context, nullptr);
Corentin Walleza2257da2016-04-19 16:43:12 -04001328 return true;
Shannon Woods53a94a82014-06-24 15:20:36 -04001329 }
Corentin Walleza2257da2016-04-19 16:43:12 -04001330
1331 return false;
Shannon Woods53a94a82014-06-24 15:20:36 -04001332}
1333
Yunchao Hea336b902017-08-02 16:05:21 +08001334void State::setProgramPipelineBinding(const Context *context, ProgramPipeline *pipeline)
1335{
1336 mProgramPipeline.set(context, pipeline);
1337}
1338
1339void State::detachProgramPipeline(const Context *context, GLuint pipeline)
1340{
1341 mProgramPipeline.set(context, nullptr);
1342}
1343
Corentin Wallezad3ae902018-03-09 13:40:42 -05001344bool State::isQueryActive(QueryType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001345{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001346 const Query *query = mActiveQueries[type].get();
1347 if (query != nullptr)
Shannon Woods53a94a82014-06-24 15:20:36 -04001348 {
Corentin Wallezad3ae902018-03-09 13:40:42 -05001349 return true;
1350 }
1351
1352 QueryType alternativeType;
1353 if (GetAlternativeQueryType(type, &alternativeType))
1354 {
1355 query = mActiveQueries[alternativeType].get();
1356 return query != nullptr;
Ian Ewell3ffd78b2016-01-22 16:09:42 -05001357 }
1358
1359 return false;
1360}
1361
1362bool State::isQueryActive(Query *query) const
1363{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001364 for (auto &queryPointer : mActiveQueries)
Ian Ewell3ffd78b2016-01-22 16:09:42 -05001365 {
Corentin Wallezad3ae902018-03-09 13:40:42 -05001366 if (queryPointer.get() == query)
Shannon Woods53a94a82014-06-24 15:20:36 -04001367 {
1368 return true;
1369 }
1370 }
1371
1372 return false;
1373}
1374
Corentin Wallezad3ae902018-03-09 13:40:42 -05001375void State::setActiveQuery(const Context *context, QueryType type, Query *query)
Shannon Woods53a94a82014-06-24 15:20:36 -04001376{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001377 mActiveQueries[type].set(context, query);
Shannon Woods53a94a82014-06-24 15:20:36 -04001378}
1379
Corentin Wallezad3ae902018-03-09 13:40:42 -05001380GLuint State::getActiveQueryId(QueryType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001381{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001382 const Query *query = getActiveQuery(type);
Shannon Woods53a94a82014-06-24 15:20:36 -04001383 return (query ? query->id() : 0u);
1384}
1385
Corentin Wallezad3ae902018-03-09 13:40:42 -05001386Query *State::getActiveQuery(QueryType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001387{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001388 return mActiveQueries[type].get();
Shannon Woods53a94a82014-06-24 15:20:36 -04001389}
1390
Corentin Wallez336129f2017-10-17 15:55:40 -04001391void State::setBufferBinding(const Context *context, BufferBinding target, Buffer *buffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001392{
Corentin Wallez336129f2017-10-17 15:55:40 -04001393 switch (target)
1394 {
1395 case BufferBinding::PixelPack:
James Darpiniane8a93c62018-01-04 18:02:24 -08001396 UpdateBufferBinding(context, &mBoundBuffers[target], buffer, target);
Corentin Wallez336129f2017-10-17 15:55:40 -04001397 mDirtyBits.set(DIRTY_BIT_PACK_BUFFER_BINDING);
1398 break;
1399 case BufferBinding::PixelUnpack:
James Darpiniane8a93c62018-01-04 18:02:24 -08001400 UpdateBufferBinding(context, &mBoundBuffers[target], buffer, target);
Corentin Wallez336129f2017-10-17 15:55:40 -04001401 mDirtyBits.set(DIRTY_BIT_UNPACK_BUFFER_BINDING);
1402 break;
1403 case BufferBinding::DrawIndirect:
James Darpiniane8a93c62018-01-04 18:02:24 -08001404 UpdateBufferBinding(context, &mBoundBuffers[target], buffer, target);
Corentin Wallez336129f2017-10-17 15:55:40 -04001405 mDirtyBits.set(DIRTY_BIT_DRAW_INDIRECT_BUFFER_BINDING);
1406 break;
Qin Jiajiaa98a2812017-11-30 18:12:06 +08001407 case BufferBinding::DispatchIndirect:
James Darpiniane8a93c62018-01-04 18:02:24 -08001408 UpdateBufferBinding(context, &mBoundBuffers[target], buffer, target);
Qin Jiajiaa98a2812017-11-30 18:12:06 +08001409 mDirtyBits.set(DIRTY_BIT_DISPATCH_INDIRECT_BUFFER_BINDING);
1410 break;
Corentin Wallez336129f2017-10-17 15:55:40 -04001411 case BufferBinding::ElementArray:
1412 getVertexArray()->setElementArrayBuffer(context, buffer);
1413 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1414 break;
Xinghua Cao10a4d432017-11-28 14:46:26 +08001415 case BufferBinding::ShaderStorage:
James Darpiniane8a93c62018-01-04 18:02:24 -08001416 UpdateBufferBinding(context, &mBoundBuffers[target], buffer, target);
Xinghua Cao10a4d432017-11-28 14:46:26 +08001417 mDirtyBits.set(DIRTY_BIT_SHADER_STORAGE_BUFFER_BINDING);
1418 break;
Corentin Wallez336129f2017-10-17 15:55:40 -04001419 default:
James Darpiniane8a93c62018-01-04 18:02:24 -08001420 UpdateBufferBinding(context, &mBoundBuffers[target], buffer, target);
Corentin Wallez336129f2017-10-17 15:55:40 -04001421 break;
1422 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001423}
James Darpiniane8a93c62018-01-04 18:02:24 -08001424
Corentin Wallez336129f2017-10-17 15:55:40 -04001425void State::setIndexedBufferBinding(const Context *context,
1426 BufferBinding target,
1427 GLuint index,
1428 Buffer *buffer,
1429 GLintptr offset,
1430 GLsizeiptr size)
Jiajia Qin9d7d0b12016-11-29 16:30:31 +08001431{
Corentin Wallez336129f2017-10-17 15:55:40 -04001432 setBufferBinding(context, target, buffer);
Jiajia Qin9d7d0b12016-11-29 16:30:31 +08001433
Corentin Wallez336129f2017-10-17 15:55:40 -04001434 switch (target)
1435 {
1436 case BufferBinding::TransformFeedback:
1437 mTransformFeedback->bindIndexedBuffer(context, index, buffer, offset, size);
James Darpiniane8a93c62018-01-04 18:02:24 -08001438 setBufferBinding(context, target, buffer);
Corentin Wallez336129f2017-10-17 15:55:40 -04001439 break;
1440 case BufferBinding::Uniform:
James Darpiniane8a93c62018-01-04 18:02:24 -08001441 UpdateBufferBinding(context, &mUniformBuffers[index], buffer, target, offset, size);
Jamie Madillf4141212017-12-12 15:08:07 -05001442 mDirtyBits.set(DIRTY_BIT_UNIFORM_BUFFER_BINDINGS);
Corentin Wallez336129f2017-10-17 15:55:40 -04001443 break;
1444 case BufferBinding::AtomicCounter:
James Darpiniane8a93c62018-01-04 18:02:24 -08001445 UpdateBufferBinding(context, &mAtomicCounterBuffers[index], buffer, target, offset,
1446 size);
Corentin Wallez336129f2017-10-17 15:55:40 -04001447 break;
1448 case BufferBinding::ShaderStorage:
James Darpiniane8a93c62018-01-04 18:02:24 -08001449 UpdateBufferBinding(context, &mShaderStorageBuffers[index], buffer, target, offset,
1450 size);
Corentin Wallez336129f2017-10-17 15:55:40 -04001451 break;
1452 default:
1453 UNREACHABLE();
1454 break;
1455 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001456}
1457
Geoff Lang5d124a62015-09-15 13:03:27 -04001458const OffsetBindingPointer<Buffer> &State::getIndexedUniformBuffer(size_t index) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001459{
Shannon Woodsf3acaf92014-09-23 18:07:11 -04001460 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
Geoff Lang5d124a62015-09-15 13:03:27 -04001461 return mUniformBuffers[index];
Gregoire Payen de La Garanderie68694e92015-03-24 14:03:37 +00001462}
1463
Jiajia Qin6eafb042016-12-27 17:04:07 +08001464const OffsetBindingPointer<Buffer> &State::getIndexedAtomicCounterBuffer(size_t index) const
1465{
1466 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
1467 return mAtomicCounterBuffers[index];
1468}
1469
Jiajia Qinf546e7d2017-03-27 14:12:59 +08001470const OffsetBindingPointer<Buffer> &State::getIndexedShaderStorageBuffer(size_t index) const
1471{
1472 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
1473 return mShaderStorageBuffers[index];
1474}
1475
Corentin Wallez336129f2017-10-17 15:55:40 -04001476Buffer *State::getTargetBuffer(BufferBinding target) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001477{
1478 switch (target)
1479 {
Corentin Wallez336129f2017-10-17 15:55:40 -04001480 case BufferBinding::ElementArray:
1481 return getVertexArray()->getElementArrayBuffer().get();
Corentin Wallez336129f2017-10-17 15:55:40 -04001482 default:
1483 return mBoundBuffers[target].get();
Shannon Woods53a94a82014-06-24 15:20:36 -04001484 }
1485}
1486
James Darpinian4d9d4832018-03-13 12:43:28 -07001487void State::detachBuffer(const Context *context, const Buffer *buffer)
Yuly Novikov5807a532015-12-03 13:01:22 -05001488{
James Darpinian4d9d4832018-03-13 12:43:28 -07001489 if (!buffer->isBound())
1490 {
1491 return;
1492 }
1493 GLuint bufferName = buffer->id();
James Darpiniane8a93c62018-01-04 18:02:24 -08001494 for (auto target : angle::AllEnums<BufferBinding>())
Yuly Novikov5807a532015-12-03 13:01:22 -05001495 {
James Darpiniane8a93c62018-01-04 18:02:24 -08001496 if (mBoundBuffers[target].id() == bufferName)
Yuly Novikov5807a532015-12-03 13:01:22 -05001497 {
James Darpiniane8a93c62018-01-04 18:02:24 -08001498 UpdateBufferBinding(context, &mBoundBuffers[target], nullptr, target);
Yuly Novikov5807a532015-12-03 13:01:22 -05001499 }
1500 }
1501
1502 TransformFeedback *curTransformFeedback = getCurrentTransformFeedback();
1503 if (curTransformFeedback)
1504 {
Jamie Madill4928b7c2017-06-20 12:57:39 -04001505 curTransformFeedback->detachBuffer(context, bufferName);
Yuly Novikov5807a532015-12-03 13:01:22 -05001506 }
1507
Jamie Madill4928b7c2017-06-20 12:57:39 -04001508 getVertexArray()->detachBuffer(context, bufferName);
James Darpiniane8a93c62018-01-04 18:02:24 -08001509
1510 for (auto &buf : mUniformBuffers)
1511 {
1512 if (buf.id() == bufferName)
1513 {
1514 UpdateBufferBinding(context, &buf, nullptr, BufferBinding::Uniform);
1515 }
1516 }
1517
1518 for (auto &buf : mAtomicCounterBuffers)
1519 {
1520 if (buf.id() == bufferName)
1521 {
1522 UpdateBufferBinding(context, &buf, nullptr, BufferBinding::AtomicCounter);
1523 }
1524 }
1525
1526 for (auto &buf : mShaderStorageBuffers)
1527 {
1528 if (buf.id() == bufferName)
1529 {
1530 UpdateBufferBinding(context, &buf, nullptr, BufferBinding::ShaderStorage);
1531 }
1532 }
Yuly Novikov5807a532015-12-03 13:01:22 -05001533}
1534
Shannon Woods53a94a82014-06-24 15:20:36 -04001535void State::setEnableVertexAttribArray(unsigned int attribNum, bool enabled)
1536{
1537 getVertexArray()->enableAttribute(attribNum, enabled);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001538 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001539}
1540
1541void State::setVertexAttribf(GLuint index, const GLfloat values[4])
1542{
Shannon Woods23e05002014-09-22 19:07:27 -04001543 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001544 mVertexAttribCurrentValues[index].setFloatValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001545 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1546 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001547 mCurrentValuesTypeMask.setIndex(GL_FLOAT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001548}
1549
1550void State::setVertexAttribu(GLuint index, const GLuint values[4])
1551{
Shannon Woods23e05002014-09-22 19:07:27 -04001552 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001553 mVertexAttribCurrentValues[index].setUnsignedIntValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001554 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1555 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001556 mCurrentValuesTypeMask.setIndex(GL_UNSIGNED_INT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001557}
1558
1559void State::setVertexAttribi(GLuint index, const GLint values[4])
1560{
Shannon Woods23e05002014-09-22 19:07:27 -04001561 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001562 mVertexAttribCurrentValues[index].setIntValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001563 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1564 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001565 mCurrentValuesTypeMask.setIndex(GL_INT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001566}
1567
Shaodde78e82017-05-22 14:13:27 +08001568void State::setVertexAttribPointer(const Context *context,
1569 unsigned int attribNum,
1570 Buffer *boundBuffer,
1571 GLint size,
1572 GLenum type,
1573 bool normalized,
1574 bool pureInteger,
1575 GLsizei stride,
1576 const void *pointer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001577{
Shaodde78e82017-05-22 14:13:27 +08001578 getVertexArray()->setVertexAttribPointer(context, attribNum, boundBuffer, size, type,
1579 normalized, pureInteger, stride, pointer);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001580 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Jamie Madill0b9e9032015-08-17 11:51:52 +00001581}
1582
Shaodde78e82017-05-22 14:13:27 +08001583void State::setVertexAttribDivisor(const Context *context, GLuint index, GLuint divisor)
Jamie Madill0b9e9032015-08-17 11:51:52 +00001584{
Shaodde78e82017-05-22 14:13:27 +08001585 getVertexArray()->setVertexAttribDivisor(context, index, divisor);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001586 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001587}
1588
Jamie Madill6de51852017-04-12 09:53:01 -04001589const VertexAttribCurrentValueData &State::getVertexAttribCurrentValue(size_t attribNum) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001590{
Jamie Madill6de51852017-04-12 09:53:01 -04001591 ASSERT(attribNum < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001592 return mVertexAttribCurrentValues[attribNum];
1593}
1594
Jamie Madillcac94a92017-11-10 10:09:32 -05001595const std::vector<VertexAttribCurrentValueData> &State::getVertexAttribCurrentValues() const
1596{
1597 return mVertexAttribCurrentValues;
1598}
1599
Shannon Woods53a94a82014-06-24 15:20:36 -04001600const void *State::getVertexAttribPointer(unsigned int attribNum) const
1601{
1602 return getVertexArray()->getVertexAttribute(attribNum).pointer;
1603}
1604
1605void State::setPackAlignment(GLint alignment)
1606{
1607 mPack.alignment = alignment;
Jamie Madillc67323a2017-11-02 23:11:41 -04001608 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001609}
1610
1611GLint State::getPackAlignment() const
1612{
1613 return mPack.alignment;
1614}
1615
1616void State::setPackReverseRowOrder(bool reverseRowOrder)
1617{
1618 mPack.reverseRowOrder = reverseRowOrder;
Jamie Madillc67323a2017-11-02 23:11:41 -04001619 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001620}
1621
1622bool State::getPackReverseRowOrder() const
1623{
1624 return mPack.reverseRowOrder;
1625}
1626
Minmin Gongadff67b2015-10-14 10:34:45 -04001627void State::setPackRowLength(GLint rowLength)
1628{
1629 mPack.rowLength = rowLength;
Jamie Madillc67323a2017-11-02 23:11:41 -04001630 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001631}
1632
1633GLint State::getPackRowLength() const
1634{
1635 return mPack.rowLength;
1636}
1637
1638void State::setPackSkipRows(GLint skipRows)
1639{
1640 mPack.skipRows = skipRows;
Jamie Madillc67323a2017-11-02 23:11:41 -04001641 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001642}
1643
1644GLint State::getPackSkipRows() const
1645{
1646 return mPack.skipRows;
1647}
1648
1649void State::setPackSkipPixels(GLint skipPixels)
1650{
1651 mPack.skipPixels = skipPixels;
Jamie Madillc67323a2017-11-02 23:11:41 -04001652 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001653}
1654
1655GLint State::getPackSkipPixels() const
1656{
1657 return mPack.skipPixels;
1658}
1659
Shannon Woods53a94a82014-06-24 15:20:36 -04001660const PixelPackState &State::getPackState() const
1661{
1662 return mPack;
1663}
1664
Jamie Madill87de3622015-03-16 10:41:44 -04001665PixelPackState &State::getPackState()
1666{
1667 return mPack;
1668}
1669
Shannon Woods53a94a82014-06-24 15:20:36 -04001670void State::setUnpackAlignment(GLint alignment)
1671{
1672 mUnpack.alignment = alignment;
Jamie Madillc67323a2017-11-02 23:11:41 -04001673 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001674}
1675
1676GLint State::getUnpackAlignment() const
1677{
1678 return mUnpack.alignment;
1679}
1680
Minmin Gongb8aee3b2015-01-27 14:42:36 -08001681void State::setUnpackRowLength(GLint rowLength)
1682{
1683 mUnpack.rowLength = rowLength;
Jamie Madillc67323a2017-11-02 23:11:41 -04001684 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongb8aee3b2015-01-27 14:42:36 -08001685}
1686
1687GLint State::getUnpackRowLength() const
1688{
1689 return mUnpack.rowLength;
1690}
1691
Minmin Gongadff67b2015-10-14 10:34:45 -04001692void State::setUnpackImageHeight(GLint imageHeight)
1693{
1694 mUnpack.imageHeight = imageHeight;
Jamie Madillc67323a2017-11-02 23:11:41 -04001695 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001696}
1697
1698GLint State::getUnpackImageHeight() const
1699{
1700 return mUnpack.imageHeight;
1701}
1702
1703void State::setUnpackSkipImages(GLint skipImages)
1704{
1705 mUnpack.skipImages = skipImages;
Jamie Madillc67323a2017-11-02 23:11:41 -04001706 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001707}
1708
1709GLint State::getUnpackSkipImages() const
1710{
1711 return mUnpack.skipImages;
1712}
1713
1714void State::setUnpackSkipRows(GLint skipRows)
1715{
1716 mUnpack.skipRows = skipRows;
Jamie Madillc67323a2017-11-02 23:11:41 -04001717 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001718}
1719
1720GLint State::getUnpackSkipRows() const
1721{
1722 return mUnpack.skipRows;
1723}
1724
1725void State::setUnpackSkipPixels(GLint skipPixels)
1726{
1727 mUnpack.skipPixels = skipPixels;
Jamie Madillc67323a2017-11-02 23:11:41 -04001728 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001729}
1730
1731GLint State::getUnpackSkipPixels() const
1732{
1733 return mUnpack.skipPixels;
1734}
1735
Shannon Woods53a94a82014-06-24 15:20:36 -04001736const PixelUnpackState &State::getUnpackState() const
1737{
1738 return mUnpack;
1739}
1740
Jamie Madill67102f02015-03-16 10:41:42 -04001741PixelUnpackState &State::getUnpackState()
1742{
1743 return mUnpack;
1744}
1745
Geoff Lang70d0f492015-12-10 17:45:46 -05001746const Debug &State::getDebug() const
1747{
1748 return mDebug;
1749}
1750
1751Debug &State::getDebug()
1752{
1753 return mDebug;
1754}
1755
Sami Väisänena797e062016-05-12 15:23:40 +03001756void State::setCoverageModulation(GLenum components)
1757{
1758 mCoverageModulation = components;
1759 mDirtyBits.set(DIRTY_BIT_COVERAGE_MODULATION);
1760}
1761
1762GLenum State::getCoverageModulation() const
1763{
1764 return mCoverageModulation;
1765}
1766
Sami Väisänene45e53b2016-05-25 10:36:04 +03001767void State::loadPathRenderingMatrix(GLenum matrixMode, const GLfloat *matrix)
1768{
1769 if (matrixMode == GL_PATH_MODELVIEW_CHROMIUM)
1770 {
1771 memcpy(mPathMatrixMV, matrix, 16 * sizeof(GLfloat));
1772 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING_MATRIX_MV);
1773 }
1774 else if (matrixMode == GL_PATH_PROJECTION_CHROMIUM)
1775 {
1776 memcpy(mPathMatrixProj, matrix, 16 * sizeof(GLfloat));
1777 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING_MATRIX_PROJ);
1778 }
1779 else
1780 {
1781 UNREACHABLE();
1782 }
1783}
1784
1785const GLfloat *State::getPathRenderingMatrix(GLenum which) const
1786{
1787 if (which == GL_PATH_MODELVIEW_MATRIX_CHROMIUM)
1788 {
1789 return mPathMatrixMV;
1790 }
1791 else if (which == GL_PATH_PROJECTION_MATRIX_CHROMIUM)
1792 {
1793 return mPathMatrixProj;
1794 }
1795
1796 UNREACHABLE();
1797 return nullptr;
1798}
1799
1800void State::setPathStencilFunc(GLenum func, GLint ref, GLuint mask)
1801{
1802 mPathStencilFunc = func;
1803 mPathStencilRef = ref;
1804 mPathStencilMask = mask;
1805 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING_STENCIL_STATE);
1806}
1807
1808GLenum State::getPathStencilFunc() const
1809{
1810 return mPathStencilFunc;
1811}
1812
1813GLint State::getPathStencilRef() const
1814{
1815 return mPathStencilRef;
1816}
1817
1818GLuint State::getPathStencilMask() const
1819{
1820 return mPathStencilMask;
1821}
1822
Geoff Lang1d2c41d2016-10-19 16:14:46 -07001823void State::setFramebufferSRGB(bool sRGB)
1824{
1825 mFramebufferSRGB = sRGB;
1826 mDirtyBits.set(DIRTY_BIT_FRAMEBUFFER_SRGB);
1827}
1828
1829bool State::getFramebufferSRGB() const
1830{
1831 return mFramebufferSRGB;
1832}
1833
Shannon Woods53a94a82014-06-24 15:20:36 -04001834void State::getBooleanv(GLenum pname, GLboolean *params)
1835{
1836 switch (pname)
1837 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001838 case GL_SAMPLE_COVERAGE_INVERT:
1839 *params = mSampleCoverageInvert;
1840 break;
1841 case GL_DEPTH_WRITEMASK:
1842 *params = mDepthStencil.depthMask;
1843 break;
1844 case GL_COLOR_WRITEMASK:
1845 params[0] = mBlend.colorMaskRed;
1846 params[1] = mBlend.colorMaskGreen;
1847 params[2] = mBlend.colorMaskBlue;
1848 params[3] = mBlend.colorMaskAlpha;
1849 break;
1850 case GL_CULL_FACE:
1851 *params = mRasterizer.cullFace;
1852 break;
1853 case GL_POLYGON_OFFSET_FILL:
1854 *params = mRasterizer.polygonOffsetFill;
1855 break;
1856 case GL_SAMPLE_ALPHA_TO_COVERAGE:
1857 *params = mBlend.sampleAlphaToCoverage;
1858 break;
1859 case GL_SAMPLE_COVERAGE:
1860 *params = mSampleCoverage;
1861 break;
1862 case GL_SAMPLE_MASK:
1863 *params = mSampleMask;
1864 break;
1865 case GL_SCISSOR_TEST:
1866 *params = mScissorTest;
1867 break;
1868 case GL_STENCIL_TEST:
1869 *params = mDepthStencil.stencilTest;
1870 break;
1871 case GL_DEPTH_TEST:
1872 *params = mDepthStencil.depthTest;
1873 break;
1874 case GL_BLEND:
1875 *params = mBlend.blend;
1876 break;
1877 case GL_DITHER:
1878 *params = mBlend.dither;
1879 break;
1880 case GL_TRANSFORM_FEEDBACK_ACTIVE:
1881 *params = getCurrentTransformFeedback()->isActive() ? GL_TRUE : GL_FALSE;
1882 break;
1883 case GL_TRANSFORM_FEEDBACK_PAUSED:
1884 *params = getCurrentTransformFeedback()->isPaused() ? GL_TRUE : GL_FALSE;
1885 break;
1886 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
1887 *params = mPrimitiveRestart;
1888 break;
1889 case GL_RASTERIZER_DISCARD:
1890 *params = isRasterizerDiscardEnabled() ? GL_TRUE : GL_FALSE;
1891 break;
1892 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
1893 *params = mDebug.isOutputSynchronous() ? GL_TRUE : GL_FALSE;
1894 break;
1895 case GL_DEBUG_OUTPUT:
1896 *params = mDebug.isOutputEnabled() ? GL_TRUE : GL_FALSE;
1897 break;
1898 case GL_MULTISAMPLE_EXT:
1899 *params = mMultiSampling;
1900 break;
1901 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
1902 *params = mSampleAlphaToOne;
1903 break;
1904 case GL_BIND_GENERATES_RESOURCE_CHROMIUM:
1905 *params = isBindGeneratesResourceEnabled() ? GL_TRUE : GL_FALSE;
1906 break;
1907 case GL_CLIENT_ARRAYS_ANGLE:
1908 *params = areClientArraysEnabled() ? GL_TRUE : GL_FALSE;
1909 break;
1910 case GL_FRAMEBUFFER_SRGB_EXT:
1911 *params = getFramebufferSRGB() ? GL_TRUE : GL_FALSE;
1912 break;
1913 case GL_ROBUST_RESOURCE_INITIALIZATION_ANGLE:
1914 *params = mRobustResourceInit ? GL_TRUE : GL_FALSE;
1915 break;
1916 case GL_PROGRAM_CACHE_ENABLED_ANGLE:
1917 *params = mProgramBinaryCacheEnabled ? GL_TRUE : GL_FALSE;
1918 break;
Lingfeng Yangd0febe72018-05-17 22:36:52 -07001919 case GL_LIGHT_MODEL_TWO_SIDE:
1920 *params = IsLightModelTwoSided(&mGLES1State);
1921 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001922 default:
1923 UNREACHABLE();
1924 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04001925 }
1926}
1927
1928void State::getFloatv(GLenum pname, GLfloat *params)
1929{
1930 // Please note: DEPTH_CLEAR_VALUE is included in our internal getFloatv implementation
1931 // because it is stored as a float, despite the fact that the GL ES 2.0 spec names
1932 // GetIntegerv as its native query function. As it would require conversion in any
1933 // case, this should make no difference to the calling application.
1934 switch (pname)
1935 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001936 case GL_LINE_WIDTH:
1937 *params = mLineWidth;
1938 break;
1939 case GL_SAMPLE_COVERAGE_VALUE:
1940 *params = mSampleCoverageValue;
1941 break;
1942 case GL_DEPTH_CLEAR_VALUE:
1943 *params = mDepthClearValue;
1944 break;
1945 case GL_POLYGON_OFFSET_FACTOR:
1946 *params = mRasterizer.polygonOffsetFactor;
1947 break;
1948 case GL_POLYGON_OFFSET_UNITS:
1949 *params = mRasterizer.polygonOffsetUnits;
1950 break;
1951 case GL_DEPTH_RANGE:
1952 params[0] = mNearZ;
1953 params[1] = mFarZ;
1954 break;
1955 case GL_COLOR_CLEAR_VALUE:
1956 params[0] = mColorClearValue.red;
1957 params[1] = mColorClearValue.green;
1958 params[2] = mColorClearValue.blue;
1959 params[3] = mColorClearValue.alpha;
1960 break;
1961 case GL_BLEND_COLOR:
1962 params[0] = mBlendColor.red;
1963 params[1] = mBlendColor.green;
1964 params[2] = mBlendColor.blue;
1965 params[3] = mBlendColor.alpha;
1966 break;
1967 case GL_MULTISAMPLE_EXT:
1968 *params = static_cast<GLfloat>(mMultiSampling);
1969 break;
1970 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
1971 *params = static_cast<GLfloat>(mSampleAlphaToOne);
1972 break;
1973 case GL_COVERAGE_MODULATION_CHROMIUM:
1974 params[0] = static_cast<GLfloat>(mCoverageModulation);
1975 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -07001976 case GL_ALPHA_TEST_REF:
1977 *params = mGLES1State.mAlphaTestRef;
1978 break;
Lingfeng Yanga43994c2018-03-29 07:21:41 -07001979 case GL_CURRENT_COLOR:
1980 {
1981 const auto &color = mGLES1State.mCurrentColor;
1982 params[0] = color.red;
1983 params[1] = color.green;
1984 params[2] = color.blue;
1985 params[3] = color.alpha;
1986 break;
1987 }
Lingfeng Yang5a7e61b2018-03-29 16:50:32 -07001988 case GL_CURRENT_NORMAL:
1989 {
1990 const auto &normal = mGLES1State.mCurrentNormal;
1991 params[0] = normal[0];
1992 params[1] = normal[1];
1993 params[2] = normal[2];
1994 break;
1995 }
Lingfeng Yang038dd532018-03-29 17:31:52 -07001996 case GL_CURRENT_TEXTURE_COORDS:
1997 {
1998 const auto &texcoord = mGLES1State.mCurrentTextureCoords[mActiveSampler];
1999 params[0] = texcoord.s;
2000 params[1] = texcoord.t;
2001 params[2] = texcoord.r;
2002 params[3] = texcoord.q;
2003 break;
2004 }
Lingfeng Yang3a41af62018-04-09 07:28:56 -07002005 case GL_MODELVIEW_MATRIX:
2006 memcpy(params, mGLES1State.mModelviewMatrices.back().data(), 16 * sizeof(GLfloat));
2007 break;
2008 case GL_PROJECTION_MATRIX:
2009 memcpy(params, mGLES1State.mProjectionMatrices.back().data(), 16 * sizeof(GLfloat));
2010 break;
2011 case GL_TEXTURE_MATRIX:
2012 memcpy(params, mGLES1State.mTextureMatrices[mActiveSampler].back().data(),
2013 16 * sizeof(GLfloat));
2014 break;
Lingfeng Yangd0febe72018-05-17 22:36:52 -07002015 case GL_LIGHT_MODEL_AMBIENT:
2016 GetLightModelParameters(&mGLES1State, pname, params);
2017 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002018 default:
2019 UNREACHABLE();
2020 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002021 }
2022}
2023
Jamie Madille98b1b52018-03-08 09:47:23 -05002024Error State::getIntegerv(const Context *context, GLenum pname, GLint *params)
Shannon Woods53a94a82014-06-24 15:20:36 -04002025{
2026 if (pname >= GL_DRAW_BUFFER0_EXT && pname <= GL_DRAW_BUFFER15_EXT)
2027 {
2028 unsigned int colorAttachment = (pname - GL_DRAW_BUFFER0_EXT);
Shannon Woods2df6a602014-09-26 16:12:07 -04002029 ASSERT(colorAttachment < mMaxDrawBuffers);
Shannon Woods53a94a82014-06-24 15:20:36 -04002030 Framebuffer *framebuffer = mDrawFramebuffer;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002031 *params = framebuffer->getDrawBufferState(colorAttachment);
Jamie Madille98b1b52018-03-08 09:47:23 -05002032 return NoError();
Shannon Woods53a94a82014-06-24 15:20:36 -04002033 }
2034
2035 // Please note: DEPTH_CLEAR_VALUE is not included in our internal getIntegerv implementation
2036 // because it is stored as a float, despite the fact that the GL ES 2.0 spec names
2037 // GetIntegerv as its native query function. As it would require conversion in any
2038 // case, this should make no difference to the calling application. You may find it in
2039 // State::getFloatv.
2040 switch (pname)
2041 {
Corentin Wallez336129f2017-10-17 15:55:40 -04002042 case GL_ARRAY_BUFFER_BINDING:
2043 *params = mBoundBuffers[BufferBinding::Array].id();
2044 break;
2045 case GL_DRAW_INDIRECT_BUFFER_BINDING:
2046 *params = mBoundBuffers[BufferBinding::DrawIndirect].id();
2047 break;
2048 case GL_ELEMENT_ARRAY_BUFFER_BINDING:
2049 *params = getVertexArray()->getElementArrayBuffer().id();
2050 break;
Jamie Madill690c8eb2018-03-12 15:20:03 -04002051 case GL_DRAW_FRAMEBUFFER_BINDING:
2052 static_assert(GL_DRAW_FRAMEBUFFER_BINDING == GL_DRAW_FRAMEBUFFER_BINDING_ANGLE,
2053 "Enum mismatch");
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002054 *params = mDrawFramebuffer->id();
2055 break;
Jamie Madill690c8eb2018-03-12 15:20:03 -04002056 case GL_READ_FRAMEBUFFER_BINDING:
2057 static_assert(GL_READ_FRAMEBUFFER_BINDING == GL_READ_FRAMEBUFFER_BINDING_ANGLE,
2058 "Enum mismatch");
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002059 *params = mReadFramebuffer->id();
2060 break;
2061 case GL_RENDERBUFFER_BINDING:
2062 *params = mRenderbuffer.id();
2063 break;
2064 case GL_VERTEX_ARRAY_BINDING:
2065 *params = mVertexArray->id();
2066 break;
2067 case GL_CURRENT_PROGRAM:
2068 *params = mProgram ? mProgram->id() : 0;
2069 break;
2070 case GL_PACK_ALIGNMENT:
2071 *params = mPack.alignment;
2072 break;
2073 case GL_PACK_REVERSE_ROW_ORDER_ANGLE:
2074 *params = mPack.reverseRowOrder;
2075 break;
2076 case GL_PACK_ROW_LENGTH:
2077 *params = mPack.rowLength;
2078 break;
2079 case GL_PACK_SKIP_ROWS:
2080 *params = mPack.skipRows;
2081 break;
2082 case GL_PACK_SKIP_PIXELS:
2083 *params = mPack.skipPixels;
2084 break;
2085 case GL_UNPACK_ALIGNMENT:
2086 *params = mUnpack.alignment;
2087 break;
2088 case GL_UNPACK_ROW_LENGTH:
2089 *params = mUnpack.rowLength;
2090 break;
2091 case GL_UNPACK_IMAGE_HEIGHT:
2092 *params = mUnpack.imageHeight;
2093 break;
2094 case GL_UNPACK_SKIP_IMAGES:
2095 *params = mUnpack.skipImages;
2096 break;
2097 case GL_UNPACK_SKIP_ROWS:
2098 *params = mUnpack.skipRows;
2099 break;
2100 case GL_UNPACK_SKIP_PIXELS:
2101 *params = mUnpack.skipPixels;
2102 break;
2103 case GL_GENERATE_MIPMAP_HINT:
2104 *params = mGenerateMipmapHint;
2105 break;
2106 case GL_FRAGMENT_SHADER_DERIVATIVE_HINT_OES:
2107 *params = mFragmentShaderDerivativeHint;
2108 break;
2109 case GL_ACTIVE_TEXTURE:
2110 *params = (static_cast<GLint>(mActiveSampler) + GL_TEXTURE0);
2111 break;
2112 case GL_STENCIL_FUNC:
2113 *params = mDepthStencil.stencilFunc;
2114 break;
2115 case GL_STENCIL_REF:
2116 *params = mStencilRef;
2117 break;
2118 case GL_STENCIL_VALUE_MASK:
2119 *params = CastMaskValue(context, mDepthStencil.stencilMask);
2120 break;
2121 case GL_STENCIL_BACK_FUNC:
2122 *params = mDepthStencil.stencilBackFunc;
2123 break;
2124 case GL_STENCIL_BACK_REF:
2125 *params = mStencilBackRef;
2126 break;
2127 case GL_STENCIL_BACK_VALUE_MASK:
2128 *params = CastMaskValue(context, mDepthStencil.stencilBackMask);
2129 break;
2130 case GL_STENCIL_FAIL:
2131 *params = mDepthStencil.stencilFail;
2132 break;
2133 case GL_STENCIL_PASS_DEPTH_FAIL:
2134 *params = mDepthStencil.stencilPassDepthFail;
2135 break;
2136 case GL_STENCIL_PASS_DEPTH_PASS:
2137 *params = mDepthStencil.stencilPassDepthPass;
2138 break;
2139 case GL_STENCIL_BACK_FAIL:
2140 *params = mDepthStencil.stencilBackFail;
2141 break;
2142 case GL_STENCIL_BACK_PASS_DEPTH_FAIL:
2143 *params = mDepthStencil.stencilBackPassDepthFail;
2144 break;
2145 case GL_STENCIL_BACK_PASS_DEPTH_PASS:
2146 *params = mDepthStencil.stencilBackPassDepthPass;
2147 break;
2148 case GL_DEPTH_FUNC:
2149 *params = mDepthStencil.depthFunc;
2150 break;
2151 case GL_BLEND_SRC_RGB:
2152 *params = mBlend.sourceBlendRGB;
2153 break;
2154 case GL_BLEND_SRC_ALPHA:
2155 *params = mBlend.sourceBlendAlpha;
2156 break;
2157 case GL_BLEND_DST_RGB:
2158 *params = mBlend.destBlendRGB;
2159 break;
2160 case GL_BLEND_DST_ALPHA:
2161 *params = mBlend.destBlendAlpha;
2162 break;
2163 case GL_BLEND_EQUATION_RGB:
2164 *params = mBlend.blendEquationRGB;
2165 break;
2166 case GL_BLEND_EQUATION_ALPHA:
2167 *params = mBlend.blendEquationAlpha;
2168 break;
2169 case GL_STENCIL_WRITEMASK:
2170 *params = CastMaskValue(context, mDepthStencil.stencilWritemask);
2171 break;
2172 case GL_STENCIL_BACK_WRITEMASK:
2173 *params = CastMaskValue(context, mDepthStencil.stencilBackWritemask);
2174 break;
2175 case GL_STENCIL_CLEAR_VALUE:
2176 *params = mStencilClearValue;
2177 break;
2178 case GL_IMPLEMENTATION_COLOR_READ_TYPE:
Jamie Madill690c8eb2018-03-12 15:20:03 -04002179 ANGLE_TRY(mReadFramebuffer->getImplementationColorReadType(
2180 context, reinterpret_cast<GLenum *>(params)));
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002181 break;
2182 case GL_IMPLEMENTATION_COLOR_READ_FORMAT:
Jamie Madill690c8eb2018-03-12 15:20:03 -04002183 ANGLE_TRY(mReadFramebuffer->getImplementationColorReadFormat(
2184 context, reinterpret_cast<GLenum *>(params)));
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002185 break;
2186 case GL_SAMPLE_BUFFERS:
2187 case GL_SAMPLES:
Shannon Woods53a94a82014-06-24 15:20:36 -04002188 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002189 Framebuffer *framebuffer = mDrawFramebuffer;
Jamie Madill427064d2018-04-13 16:20:34 -04002190 if (framebuffer->isComplete(context))
Shannon Woods53a94a82014-06-24 15:20:36 -04002191 {
Jamie Madill427064d2018-04-13 16:20:34 -04002192 GLint samples = framebuffer->getSamples(context);
Shannon Woods53a94a82014-06-24 15:20:36 -04002193 switch (pname)
2194 {
Jamie Madilla0016b72017-07-14 14:30:46 -04002195 case GL_SAMPLE_BUFFERS:
Jamie Madille98b1b52018-03-08 09:47:23 -05002196 if (samples != 0)
Jamie Madilla0016b72017-07-14 14:30:46 -04002197 {
2198 *params = 1;
2199 }
2200 else
2201 {
2202 *params = 0;
2203 }
2204 break;
2205 case GL_SAMPLES:
Jamie Madille98b1b52018-03-08 09:47:23 -05002206 *params = samples;
Jamie Madilla0016b72017-07-14 14:30:46 -04002207 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002208 }
2209 }
2210 else
2211 {
2212 *params = 0;
2213 }
2214 }
2215 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002216 case GL_VIEWPORT:
2217 params[0] = mViewport.x;
2218 params[1] = mViewport.y;
2219 params[2] = mViewport.width;
2220 params[3] = mViewport.height;
2221 break;
2222 case GL_SCISSOR_BOX:
2223 params[0] = mScissor.x;
2224 params[1] = mScissor.y;
2225 params[2] = mScissor.width;
2226 params[3] = mScissor.height;
2227 break;
2228 case GL_CULL_FACE_MODE:
2229 *params = ToGLenum(mRasterizer.cullMode);
2230 break;
2231 case GL_FRONT_FACE:
2232 *params = mRasterizer.frontFace;
2233 break;
2234 case GL_RED_BITS:
2235 case GL_GREEN_BITS:
2236 case GL_BLUE_BITS:
2237 case GL_ALPHA_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002238 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002239 Framebuffer *framebuffer = getDrawFramebuffer();
2240 const FramebufferAttachment *colorbuffer = framebuffer->getFirstColorbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002241
2242 if (colorbuffer)
2243 {
2244 switch (pname)
2245 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002246 case GL_RED_BITS:
2247 *params = colorbuffer->getRedSize();
2248 break;
2249 case GL_GREEN_BITS:
2250 *params = colorbuffer->getGreenSize();
2251 break;
2252 case GL_BLUE_BITS:
2253 *params = colorbuffer->getBlueSize();
2254 break;
2255 case GL_ALPHA_BITS:
2256 *params = colorbuffer->getAlphaSize();
2257 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002258 }
2259 }
2260 else
2261 {
2262 *params = 0;
2263 }
2264 }
2265 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002266 case GL_DEPTH_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002267 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002268 const Framebuffer *framebuffer = getDrawFramebuffer();
2269 const FramebufferAttachment *depthbuffer = framebuffer->getDepthbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002270
2271 if (depthbuffer)
2272 {
2273 *params = depthbuffer->getDepthSize();
2274 }
2275 else
2276 {
2277 *params = 0;
2278 }
2279 }
2280 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002281 case GL_STENCIL_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002282 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002283 const Framebuffer *framebuffer = getDrawFramebuffer();
2284 const FramebufferAttachment *stencilbuffer = framebuffer->getStencilbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002285
2286 if (stencilbuffer)
2287 {
2288 *params = stencilbuffer->getStencilSize();
2289 }
2290 else
2291 {
2292 *params = 0;
2293 }
2294 }
2295 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002296 case GL_TEXTURE_BINDING_2D:
2297 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2298 *params =
2299 getSamplerTextureId(static_cast<unsigned int>(mActiveSampler), TextureType::_2D);
2300 break;
2301 case GL_TEXTURE_BINDING_RECTANGLE_ANGLE:
2302 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2303 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2304 TextureType::Rectangle);
2305 break;
2306 case GL_TEXTURE_BINDING_CUBE_MAP:
2307 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2308 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2309 TextureType::CubeMap);
2310 break;
2311 case GL_TEXTURE_BINDING_3D:
2312 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2313 *params =
2314 getSamplerTextureId(static_cast<unsigned int>(mActiveSampler), TextureType::_3D);
2315 break;
2316 case GL_TEXTURE_BINDING_2D_ARRAY:
2317 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2318 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2319 TextureType::_2DArray);
2320 break;
2321 case GL_TEXTURE_BINDING_2D_MULTISAMPLE:
2322 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2323 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2324 TextureType::_2DMultisample);
2325 break;
2326 case GL_TEXTURE_BINDING_EXTERNAL_OES:
2327 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2328 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2329 TextureType::External);
2330 break;
2331 case GL_UNIFORM_BUFFER_BINDING:
2332 *params = mBoundBuffers[BufferBinding::Uniform].id();
2333 break;
2334 case GL_TRANSFORM_FEEDBACK_BINDING:
2335 *params = mTransformFeedback.id();
2336 break;
2337 case GL_TRANSFORM_FEEDBACK_BUFFER_BINDING:
2338 *params = mBoundBuffers[BufferBinding::TransformFeedback].id();
2339 break;
2340 case GL_COPY_READ_BUFFER_BINDING:
2341 *params = mBoundBuffers[BufferBinding::CopyRead].id();
2342 break;
2343 case GL_COPY_WRITE_BUFFER_BINDING:
2344 *params = mBoundBuffers[BufferBinding::CopyWrite].id();
2345 break;
2346 case GL_PIXEL_PACK_BUFFER_BINDING:
2347 *params = mBoundBuffers[BufferBinding::PixelPack].id();
2348 break;
2349 case GL_PIXEL_UNPACK_BUFFER_BINDING:
2350 *params = mBoundBuffers[BufferBinding::PixelUnpack].id();
2351 break;
2352 case GL_READ_BUFFER:
2353 *params = mReadFramebuffer->getReadBufferState();
2354 break;
2355 case GL_SAMPLER_BINDING:
2356 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2357 *params = getSamplerId(static_cast<GLuint>(mActiveSampler));
2358 break;
2359 case GL_DEBUG_LOGGED_MESSAGES:
2360 *params = static_cast<GLint>(mDebug.getMessageCount());
2361 break;
2362 case GL_DEBUG_NEXT_LOGGED_MESSAGE_LENGTH:
2363 *params = static_cast<GLint>(mDebug.getNextMessageLength());
2364 break;
2365 case GL_DEBUG_GROUP_STACK_DEPTH:
2366 *params = static_cast<GLint>(mDebug.getGroupStackDepth());
2367 break;
2368 case GL_MULTISAMPLE_EXT:
2369 *params = static_cast<GLint>(mMultiSampling);
2370 break;
2371 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
2372 *params = static_cast<GLint>(mSampleAlphaToOne);
2373 break;
2374 case GL_COVERAGE_MODULATION_CHROMIUM:
2375 *params = static_cast<GLint>(mCoverageModulation);
2376 break;
2377 case GL_ATOMIC_COUNTER_BUFFER_BINDING:
2378 *params = mBoundBuffers[BufferBinding::AtomicCounter].id();
2379 break;
2380 case GL_SHADER_STORAGE_BUFFER_BINDING:
2381 *params = mBoundBuffers[BufferBinding::ShaderStorage].id();
2382 break;
2383 case GL_DISPATCH_INDIRECT_BUFFER_BINDING:
2384 *params = mBoundBuffers[BufferBinding::DispatchIndirect].id();
2385 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -07002386 case GL_ALPHA_TEST_FUNC:
2387 *params = ToGLenum(mGLES1State.mAlphaTestFunc);
2388 break;
Lingfeng Yang96310cd2018-03-28 11:56:28 -07002389 case GL_CLIENT_ACTIVE_TEXTURE:
2390 *params = mGLES1State.mClientActiveTexture + GL_TEXTURE0;
2391 break;
Lingfeng Yangd2488ab2018-04-04 09:25:48 -07002392 case GL_MATRIX_MODE:
2393 *params = ToGLenum(mGLES1State.mMatrixMode);
2394 break;
Lingfeng Yanga0cfa872018-05-30 21:12:17 -07002395 case GL_SHADE_MODEL:
2396 *params = ToGLenum(mGLES1State.mShadeModel);
2397 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002398 default:
2399 UNREACHABLE();
2400 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002401 }
Jamie Madille98b1b52018-03-08 09:47:23 -05002402
2403 return NoError();
Shannon Woods53a94a82014-06-24 15:20:36 -04002404}
2405
Lingfeng Yangabb09f12018-04-16 10:43:53 -07002406void State::getPointerv(const Context *context, GLenum pname, void **params) const
Geoff Lang70d0f492015-12-10 17:45:46 -05002407{
2408 switch (pname)
2409 {
2410 case GL_DEBUG_CALLBACK_FUNCTION:
2411 *params = reinterpret_cast<void *>(mDebug.getCallback());
2412 break;
2413 case GL_DEBUG_CALLBACK_USER_PARAM:
2414 *params = const_cast<void *>(mDebug.getUserParam());
2415 break;
Lingfeng Yangabb09f12018-04-16 10:43:53 -07002416 case GL_VERTEX_ARRAY_POINTER:
2417 case GL_NORMAL_ARRAY_POINTER:
2418 case GL_COLOR_ARRAY_POINTER:
2419 case GL_TEXTURE_COORD_ARRAY_POINTER:
2420 case GL_POINT_SIZE_ARRAY_POINTER_OES:
2421 QueryVertexAttribPointerv(getVertexArray()->getVertexAttribute(
2422 context->vertexArrayIndex(ParamToVertexArrayType(pname))),
2423 GL_VERTEX_ATTRIB_ARRAY_POINTER, params);
2424 return;
Geoff Lang70d0f492015-12-10 17:45:46 -05002425 default:
2426 UNREACHABLE();
2427 break;
2428 }
2429}
2430
Martin Radev66fb8202016-07-28 11:45:20 +03002431void State::getIntegeri_v(GLenum target, GLuint index, GLint *data)
Shannon Woods53a94a82014-06-24 15:20:36 -04002432{
2433 switch (target)
2434 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002435 case GL_TRANSFORM_FEEDBACK_BUFFER_BINDING:
2436 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2437 *data = mTransformFeedback->getIndexedBuffer(index).id();
2438 break;
2439 case GL_UNIFORM_BUFFER_BINDING:
2440 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2441 *data = mUniformBuffers[index].id();
2442 break;
2443 case GL_ATOMIC_COUNTER_BUFFER_BINDING:
2444 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2445 *data = mAtomicCounterBuffers[index].id();
2446 break;
2447 case GL_SHADER_STORAGE_BUFFER_BINDING:
2448 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2449 *data = mShaderStorageBuffers[index].id();
2450 break;
2451 case GL_VERTEX_BINDING_BUFFER:
2452 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2453 *data = mVertexArray->getVertexBinding(index).getBuffer().id();
2454 break;
2455 case GL_VERTEX_BINDING_DIVISOR:
2456 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2457 *data = mVertexArray->getVertexBinding(index).getDivisor();
2458 break;
2459 case GL_VERTEX_BINDING_OFFSET:
2460 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2461 *data = static_cast<GLuint>(mVertexArray->getVertexBinding(index).getOffset());
2462 break;
2463 case GL_VERTEX_BINDING_STRIDE:
2464 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2465 *data = mVertexArray->getVertexBinding(index).getStride();
2466 break;
2467 case GL_SAMPLE_MASK_VALUE:
2468 ASSERT(static_cast<size_t>(index) < mSampleMaskValues.size());
2469 *data = mSampleMaskValues[index];
2470 break;
2471 case GL_IMAGE_BINDING_NAME:
2472 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2473 *data = mImageUnits[index].texture.id();
2474 break;
2475 case GL_IMAGE_BINDING_LEVEL:
2476 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2477 *data = mImageUnits[index].level;
2478 break;
2479 case GL_IMAGE_BINDING_LAYER:
2480 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2481 *data = mImageUnits[index].layer;
2482 break;
2483 case GL_IMAGE_BINDING_ACCESS:
2484 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2485 *data = mImageUnits[index].access;
2486 break;
2487 case GL_IMAGE_BINDING_FORMAT:
2488 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2489 *data = mImageUnits[index].format;
2490 break;
2491 default:
2492 UNREACHABLE();
2493 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002494 }
Shannon Woods53a94a82014-06-24 15:20:36 -04002495}
2496
Martin Radev66fb8202016-07-28 11:45:20 +03002497void State::getInteger64i_v(GLenum target, GLuint index, GLint64 *data)
Shannon Woods53a94a82014-06-24 15:20:36 -04002498{
2499 switch (target)
2500 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002501 case GL_TRANSFORM_FEEDBACK_BUFFER_START:
2502 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2503 *data = mTransformFeedback->getIndexedBuffer(index).getOffset();
2504 break;
2505 case GL_TRANSFORM_FEEDBACK_BUFFER_SIZE:
2506 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2507 *data = mTransformFeedback->getIndexedBuffer(index).getSize();
2508 break;
2509 case GL_UNIFORM_BUFFER_START:
2510 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2511 *data = mUniformBuffers[index].getOffset();
2512 break;
2513 case GL_UNIFORM_BUFFER_SIZE:
2514 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2515 *data = mUniformBuffers[index].getSize();
2516 break;
2517 case GL_ATOMIC_COUNTER_BUFFER_START:
2518 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2519 *data = mAtomicCounterBuffers[index].getOffset();
2520 break;
2521 case GL_ATOMIC_COUNTER_BUFFER_SIZE:
2522 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2523 *data = mAtomicCounterBuffers[index].getSize();
2524 break;
2525 case GL_SHADER_STORAGE_BUFFER_START:
2526 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2527 *data = mShaderStorageBuffers[index].getOffset();
2528 break;
2529 case GL_SHADER_STORAGE_BUFFER_SIZE:
2530 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2531 *data = mShaderStorageBuffers[index].getSize();
2532 break;
2533 default:
2534 UNREACHABLE();
2535 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002536 }
Martin Radev66fb8202016-07-28 11:45:20 +03002537}
Shannon Woods53a94a82014-06-24 15:20:36 -04002538
Martin Radev66fb8202016-07-28 11:45:20 +03002539void State::getBooleani_v(GLenum target, GLuint index, GLboolean *data)
2540{
Xinghua Cao9c8e1a32017-12-06 17:59:58 +08002541 switch (target)
2542 {
2543 case GL_IMAGE_BINDING_LAYERED:
2544 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2545 *data = mImageUnits[index].layered;
2546 break;
2547 default:
2548 UNREACHABLE();
2549 break;
2550 }
Shannon Woods53a94a82014-06-24 15:20:36 -04002551}
2552
Corentin Wallez336129f2017-10-17 15:55:40 -04002553bool State::hasMappedBuffer(BufferBinding target) const
Jamie Madilld9ba4f72014-08-04 10:47:59 -04002554{
Corentin Wallez336129f2017-10-17 15:55:40 -04002555 if (target == BufferBinding::Array)
Jamie Madilld9ba4f72014-08-04 10:47:59 -04002556 {
Jiawei-Shao2597fb62016-12-09 16:38:02 +08002557 const VertexArray *vao = getVertexArray();
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002558 const auto &vertexAttribs = vao->getVertexAttributes();
Jiawei-Shao2597fb62016-12-09 16:38:02 +08002559 const auto &vertexBindings = vao->getVertexBindings();
Jamie Madilld078c682018-01-02 11:50:24 -05002560 for (size_t attribIndex : vao->getEnabledAttributesMask())
Jamie Madilld9ba4f72014-08-04 10:47:59 -04002561 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002562 const VertexAttribute &vertexAttrib = vertexAttribs[attribIndex];
Martin Radevdd5f27e2017-06-07 10:17:09 +03002563 auto *boundBuffer = vertexBindings[vertexAttrib.bindingIndex].getBuffer().get();
Jamie Madilld9ba4f72014-08-04 10:47:59 -04002564 if (vertexAttrib.enabled && boundBuffer && boundBuffer->isMapped())
2565 {
2566 return true;
2567 }
2568 }
2569
2570 return false;
2571 }
2572 else
2573 {
2574 Buffer *buffer = getTargetBuffer(target);
2575 return (buffer && buffer->isMapped());
2576 }
2577}
2578
Jamie Madillbc918e72018-03-08 09:47:21 -05002579Error State::syncDirtyObjects(const Context *context)
Jamie Madillc9d442d2016-01-20 11:17:24 -05002580{
2581 if (!mDirtyObjects.any())
Jamie Madillbc918e72018-03-08 09:47:21 -05002582 return NoError();
Jamie Madillc9d442d2016-01-20 11:17:24 -05002583
Jamie Madillbc918e72018-03-08 09:47:21 -05002584 return syncDirtyObjects(context, mDirtyObjects);
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002585}
2586
Jamie Madillbc918e72018-03-08 09:47:21 -05002587Error State::syncDirtyObjects(const Context *context, const DirtyObjects &bitset)
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002588{
Jiajia Qin5ae6ee42018-03-06 17:39:42 +08002589 const DirtyObjects &dirtyObjects = mDirtyObjects & bitset;
2590 for (auto dirtyObject : dirtyObjects)
Jamie Madillc9d442d2016-01-20 11:17:24 -05002591 {
2592 switch (dirtyObject)
2593 {
2594 case DIRTY_OBJECT_READ_FRAMEBUFFER:
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002595 ASSERT(mReadFramebuffer);
Jamie Madill19fa1c62018-03-08 09:47:21 -05002596 ANGLE_TRY(mReadFramebuffer->syncState(context));
Jamie Madillc9d442d2016-01-20 11:17:24 -05002597 break;
2598 case DIRTY_OBJECT_DRAW_FRAMEBUFFER:
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002599 ASSERT(mDrawFramebuffer);
Jamie Madill19fa1c62018-03-08 09:47:21 -05002600 ANGLE_TRY(mDrawFramebuffer->syncState(context));
Jamie Madillc9d442d2016-01-20 11:17:24 -05002601 break;
2602 case DIRTY_OBJECT_VERTEX_ARRAY:
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002603 ASSERT(mVertexArray);
Frank Henigman0af5b862018-03-27 20:19:33 -04002604 ANGLE_TRY(mVertexArray->syncState(context));
Jamie Madillc9d442d2016-01-20 11:17:24 -05002605 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002606 case DIRTY_OBJECT_PROGRAM_TEXTURES:
Luc Ferron4bba74f2018-04-19 14:40:45 -04002607 ANGLE_TRY(syncProgramTextures(context));
Jamie Madill81c2e252017-09-09 23:32:46 -04002608 break;
2609
Jamie Madillc9d442d2016-01-20 11:17:24 -05002610 default:
2611 UNREACHABLE();
2612 break;
2613 }
2614 }
2615
Jiajia Qin5ae6ee42018-03-06 17:39:42 +08002616 mDirtyObjects &= ~dirtyObjects;
Jamie Madillbc918e72018-03-08 09:47:21 -05002617 return NoError();
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002618}
2619
Luc Ferron4bba74f2018-04-19 14:40:45 -04002620Error State::syncProgramTextures(const Context *context)
Jamie Madill81c2e252017-09-09 23:32:46 -04002621{
Jamie Madill81c2e252017-09-09 23:32:46 -04002622 // TODO(jmadill): Fine-grained updates.
2623 if (!mProgram)
2624 {
Luc Ferron4bba74f2018-04-19 14:40:45 -04002625 return NoError();
Jamie Madill81c2e252017-09-09 23:32:46 -04002626 }
2627
2628 ASSERT(mDirtyObjects[DIRTY_OBJECT_PROGRAM_TEXTURES]);
2629 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
2630
Jamie Madill0f80ed82017-09-19 00:24:56 -04002631 ActiveTextureMask newActiveTextures;
2632
Geoff Lange51ba632017-11-21 11:45:25 -05002633 // Initialize to the 'Initialized' state and set to 'MayNeedInit' if any texture is not
2634 // initialized.
2635 mCachedTexturesInitState = InitState::Initialized;
2636
Jamie Madill81c2e252017-09-09 23:32:46 -04002637 for (const SamplerBinding &samplerBinding : mProgram->getSamplerBindings())
2638 {
2639 if (samplerBinding.unreferenced)
2640 continue;
2641
Corentin Wallezf0e89be2017-11-08 14:00:32 -08002642 TextureType textureType = samplerBinding.textureType;
Jamie Madill81c2e252017-09-09 23:32:46 -04002643 for (GLuint textureUnitIndex : samplerBinding.boundTextureUnits)
2644 {
2645 Texture *texture = getSamplerTexture(textureUnitIndex, textureType);
Jamie Madill06ef36b2017-09-09 23:32:46 -04002646 Sampler *sampler = getSampler(textureUnitIndex);
Jamie Madill0f80ed82017-09-19 00:24:56 -04002647 ASSERT(static_cast<size_t>(textureUnitIndex) < mCompleteTextureCache.size());
2648 ASSERT(static_cast<size_t>(textureUnitIndex) < newActiveTextures.size());
Jamie Madill81c2e252017-09-09 23:32:46 -04002649
Jamie Madill42975642017-10-12 12:31:51 -04002650 ASSERT(texture);
Jamie Madill81c2e252017-09-09 23:32:46 -04002651
Jamie Madill42975642017-10-12 12:31:51 -04002652 // Mark the texture binding bit as dirty if the texture completeness changes.
2653 // TODO(jmadill): Use specific dirty bit for completeness change.
2654 if (texture->isSamplerComplete(context, sampler) &&
2655 !mDrawFramebuffer->hasTextureAttachment(texture))
2656 {
Luc Ferron4bba74f2018-04-19 14:40:45 -04002657 ANGLE_TRY(texture->syncState(context));
Jamie Madill42975642017-10-12 12:31:51 -04002658 mCompleteTextureCache[textureUnitIndex] = texture;
Jamie Madill81c2e252017-09-09 23:32:46 -04002659 }
Jamie Madill42975642017-10-12 12:31:51 -04002660 else
2661 {
2662 mCompleteTextureCache[textureUnitIndex] = nullptr;
2663 }
2664
2665 // Bind the texture unconditionally, to recieve completeness change notifications.
Jamie Madill888081d2018-02-27 00:24:46 -05002666 mCompleteTextureBindings[textureUnitIndex].bind(texture->getSubject());
Jamie Madilla59fc192017-11-02 12:57:58 -04002667 mActiveTexturesMask.set(textureUnitIndex);
Jamie Madill42975642017-10-12 12:31:51 -04002668 newActiveTextures.set(textureUnitIndex);
Jamie Madill81c2e252017-09-09 23:32:46 -04002669
Jamie Madill06ef36b2017-09-09 23:32:46 -04002670 if (sampler != nullptr)
2671 {
2672 sampler->syncState(context);
2673 }
Geoff Lange51ba632017-11-21 11:45:25 -05002674
2675 if (texture->initState() == InitState::MayNeedInit)
2676 {
2677 mCachedTexturesInitState = InitState::MayNeedInit;
2678 }
Jamie Madill81c2e252017-09-09 23:32:46 -04002679 }
2680 }
Jamie Madill0f80ed82017-09-19 00:24:56 -04002681
2682 // Unset now missing textures.
Jamie Madilla59fc192017-11-02 12:57:58 -04002683 ActiveTextureMask negativeMask = mActiveTexturesMask & ~newActiveTextures;
Jamie Madill0f80ed82017-09-19 00:24:56 -04002684 if (negativeMask.any())
2685 {
2686 for (auto textureIndex : negativeMask)
2687 {
2688 mCompleteTextureBindings[textureIndex].reset();
2689 mCompleteTextureCache[textureIndex] = nullptr;
Jamie Madilla59fc192017-11-02 12:57:58 -04002690 mActiveTexturesMask.reset(textureIndex);
Jamie Madill0f80ed82017-09-19 00:24:56 -04002691 }
2692 }
Luc Ferron4bba74f2018-04-19 14:40:45 -04002693
2694 return NoError();
Jamie Madill81c2e252017-09-09 23:32:46 -04002695}
2696
Jamie Madillbc918e72018-03-08 09:47:21 -05002697Error State::syncDirtyObject(const Context *context, GLenum target)
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002698{
2699 DirtyObjects localSet;
2700
2701 switch (target)
2702 {
2703 case GL_READ_FRAMEBUFFER:
2704 localSet.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2705 break;
2706 case GL_DRAW_FRAMEBUFFER:
2707 localSet.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2708 break;
2709 case GL_FRAMEBUFFER:
2710 localSet.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2711 localSet.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2712 break;
2713 case GL_VERTEX_ARRAY:
2714 localSet.set(DIRTY_OBJECT_VERTEX_ARRAY);
2715 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002716 case GL_TEXTURE:
2717 case GL_SAMPLER:
2718 case GL_PROGRAM:
2719 localSet.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
2720 break;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002721 }
2722
Jamie Madillbc918e72018-03-08 09:47:21 -05002723 return syncDirtyObjects(context, localSet);
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002724}
2725
2726void State::setObjectDirty(GLenum target)
2727{
2728 switch (target)
2729 {
2730 case GL_READ_FRAMEBUFFER:
2731 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2732 break;
2733 case GL_DRAW_FRAMEBUFFER:
2734 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2735 break;
2736 case GL_FRAMEBUFFER:
2737 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2738 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2739 break;
2740 case GL_VERTEX_ARRAY:
2741 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
2742 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002743 case GL_TEXTURE:
2744 case GL_SAMPLER:
Jamie Madill81c2e252017-09-09 23:32:46 -04002745 case GL_PROGRAM:
2746 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
2747 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
2748 break;
Jamie Madilla779b612017-07-24 11:46:05 -04002749 }
2750}
2751
Jamie Madill888081d2018-02-27 00:24:46 -05002752void State::setFramebufferDirty(const Framebuffer *framebuffer) const
2753{
2754 if (framebuffer == mReadFramebuffer)
2755 {
2756 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2757 }
2758 if (framebuffer == mDrawFramebuffer)
2759 {
2760 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2761 }
2762}
2763
Jamie Madill09463932018-04-04 05:26:59 -04002764void State::setVertexArrayDirty(const VertexArray *vertexArray) const
2765{
2766 if (vertexArray == mVertexArray)
2767 {
2768 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
2769 }
2770}
2771
Jamie Madilla779b612017-07-24 11:46:05 -04002772void State::onProgramExecutableChange(Program *program)
2773{
2774 // OpenGL Spec:
2775 // "If LinkProgram or ProgramBinary successfully re-links a program object
2776 // that was already in use as a result of a previous call to UseProgram, then the
2777 // generated executable code will be installed as part of the current rendering state."
2778 if (program->isLinked() && mProgram == program)
2779 {
2780 mDirtyBits.set(DIRTY_BIT_PROGRAM_EXECUTABLE);
Jamie Madill81c2e252017-09-09 23:32:46 -04002781 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002782 }
Shannon Woods53a94a82014-06-24 15:20:36 -04002783}
Jamie Madillc9d442d2016-01-20 11:17:24 -05002784
Xinghua Cao65ec0b22017-03-28 16:10:52 +08002785void State::setImageUnit(const Context *context,
2786 GLuint unit,
2787 Texture *texture,
2788 GLint level,
2789 GLboolean layered,
2790 GLint layer,
2791 GLenum access,
2792 GLenum format)
2793{
2794 mImageUnits[unit].texture.set(context, texture);
2795 mImageUnits[unit].level = level;
2796 mImageUnits[unit].layered = layered;
2797 mImageUnits[unit].layer = layer;
2798 mImageUnits[unit].access = access;
2799 mImageUnits[unit].format = format;
2800}
2801
2802const ImageUnit &State::getImageUnit(GLuint unit) const
2803{
2804 return mImageUnits[unit];
2805}
2806
Jamie Madill81c2e252017-09-09 23:32:46 -04002807// Handle a dirty texture event.
Jamie Madilld4442552018-02-27 22:03:47 -05002808void State::onSubjectStateChange(const Context *context,
2809 angle::SubjectIndex index,
2810 angle::SubjectMessage message)
Jamie Madill81c2e252017-09-09 23:32:46 -04002811{
2812 // Conservatively assume all textures are dirty.
2813 // TODO(jmadill): More fine-grained update.
2814 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Geoff Lange51ba632017-11-21 11:45:25 -05002815
Jamie Madilld4442552018-02-27 22:03:47 -05002816 if (!mCompleteTextureCache[index] ||
2817 mCompleteTextureCache[index]->initState() == InitState::MayNeedInit)
Geoff Lange51ba632017-11-21 11:45:25 -05002818 {
2819 mCachedTexturesInitState = InitState::MayNeedInit;
2820 }
Jamie Madill81c2e252017-09-09 23:32:46 -04002821}
2822
Jamie Madill05b35b22017-10-03 09:01:44 -04002823Error State::clearUnclearedActiveTextures(const Context *context)
2824{
Jamie Madilla59fc192017-11-02 12:57:58 -04002825 ASSERT(mRobustResourceInit);
Jamie Madill05b35b22017-10-03 09:01:44 -04002826
Geoff Lange51ba632017-11-21 11:45:25 -05002827 if (mCachedTexturesInitState == InitState::Initialized)
2828 {
2829 return NoError();
2830 }
2831
Geoff Langd4fff502017-09-22 11:28:28 -04002832 ASSERT(!mDirtyObjects.any());
2833
Jamie Madilla59fc192017-11-02 12:57:58 -04002834 for (auto textureIndex : mActiveTexturesMask)
Jamie Madill05b35b22017-10-03 09:01:44 -04002835 {
Jamie Madilla59fc192017-11-02 12:57:58 -04002836 Texture *texture = mCompleteTextureCache[textureIndex];
Jamie Madill05b35b22017-10-03 09:01:44 -04002837 if (texture)
2838 {
2839 ANGLE_TRY(texture->ensureInitialized(context));
2840 }
2841 }
Jamie Madilla59fc192017-11-02 12:57:58 -04002842
Geoff Lange51ba632017-11-21 11:45:25 -05002843 mCachedTexturesInitState = InitState::Initialized;
2844
Jamie Madill05b35b22017-10-03 09:01:44 -04002845 return NoError();
2846}
2847
Jamie Madillc67323a2017-11-02 23:11:41 -04002848AttributesMask State::getAndResetDirtyCurrentValues() const
2849{
2850 AttributesMask retVal = mDirtyCurrentValues;
2851 mDirtyCurrentValues.reset();
2852 return retVal;
2853}
2854
James Darpiniane8a93c62018-01-04 18:02:24 -08002855bool State::isCurrentTransformFeedback(const TransformFeedback *tf) const
2856{
2857 return tf == mTransformFeedback.get();
2858}
2859bool State::isCurrentVertexArray(const VertexArray *va) const
2860{
2861 return va == mVertexArray;
2862}
2863
Jamie Madillc9d442d2016-01-20 11:17:24 -05002864} // namespace gl