blob: 0f966df16f8c689ec63648f2974570e182bb0086 [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
Geoff Lang4fb8a8b2018-06-01 16:47:57 -040078State::State(bool debug,
79 bool bindGeneratesResource,
80 bool clientArraysEnabled,
81 bool robustResourceInit,
82 bool programBinaryCacheEnabled)
Jamie Madille79b1e12015-11-04 16:36:37 -050083 : mMaxDrawBuffers(0),
84 mMaxCombinedTextureImageUnits(0),
85 mDepthClearValue(0),
86 mStencilClearValue(0),
87 mScissorTest(false),
88 mSampleCoverage(false),
89 mSampleCoverageValue(0),
90 mSampleCoverageInvert(false),
Jiawei Shaodb342272017-09-27 10:21:45 +080091 mSampleMask(false),
92 mMaxSampleMaskWords(0),
Jamie Madille79b1e12015-11-04 16:36:37 -050093 mStencilRef(0),
94 mStencilBackRef(0),
95 mLineWidth(0),
96 mGenerateMipmapHint(GL_NONE),
97 mFragmentShaderDerivativeHint(GL_NONE),
Geoff Lang4fb8a8b2018-06-01 16:47:57 -040098 mBindGeneratesResource(bindGeneratesResource),
99 mClientArraysEnabled(clientArraysEnabled),
Jamie Madille79b1e12015-11-04 16:36:37 -0500100 mNearZ(0),
101 mFarZ(0),
102 mReadFramebuffer(nullptr),
103 mDrawFramebuffer(nullptr),
104 mProgram(nullptr),
105 mVertexArray(nullptr),
106 mActiveSampler(0),
Sami Väisänen74c23472016-05-09 17:30:30 +0300107 mPrimitiveRestart(false),
Geoff Lang4fb8a8b2018-06-01 16:47:57 -0400108 mDebug(debug),
Sami Väisänen74c23472016-05-09 17:30:30 +0300109 mMultiSampling(false),
Geoff Lang1d2c41d2016-10-19 16:14:46 -0700110 mSampleAlphaToOne(false),
Jamie Madille08a1d32017-03-07 17:24:06 -0500111 mFramebufferSRGB(true),
Geoff Lang4fb8a8b2018-06-01 16:47:57 -0400112 mRobustResourceInit(robustResourceInit),
113 mProgramBinaryCacheEnabled(programBinaryCacheEnabled)
Shannon Woods53a94a82014-06-24 15:20:36 -0400114{
Geoff Lang76b10c92014-09-05 16:28:14 -0400115}
116
Lingfeng Yang13b708f2018-03-21 12:14:10 -0700117State::~State()
118{
119}
Geoff Lang76b10c92014-09-05 16:28:14 -0400120
Geoff Lang4fb8a8b2018-06-01 16:47:57 -0400121void State::initialize(const Context *context)
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
161 mLineWidth = 1.0f;
162
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700163 mViewport.x = 0;
164 mViewport.y = 0;
165 mViewport.width = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400166 mViewport.height = 0;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700167 mNearZ = 0.0f;
168 mFarZ = 1.0f;
Shannon Woods53a94a82014-06-24 15:20:36 -0400169
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700170 mBlend.colorMaskRed = true;
Shannon Woods53a94a82014-06-24 15:20:36 -0400171 mBlend.colorMaskGreen = true;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700172 mBlend.colorMaskBlue = true;
Shannon Woods53a94a82014-06-24 15:20:36 -0400173 mBlend.colorMaskAlpha = true;
174
Geoff Lang76b10c92014-09-05 16:28:14 -0400175 mActiveSampler = 0;
176
Shannon Woods23e05002014-09-22 19:07:27 -0400177 mVertexAttribCurrentValues.resize(caps.maxVertexAttributes);
Shannon Woods53a94a82014-06-24 15:20:36 -0400178
Brandon Jonesc405ae72017-12-06 14:15:03 -0800179 // Set all indexes in state attributes type mask to float (default)
180 for (int i = 0; i < MAX_VERTEX_ATTRIBS; i++)
181 {
182 mCurrentValuesTypeMask.setIndex(GL_FLOAT, i);
183 }
184
Geoff Lang4dc3af02016-11-18 14:09:27 -0500185 mUniformBuffers.resize(caps.maxUniformBufferBindings);
Shannon Woodsf3acaf92014-09-23 18:07:11 -0400186
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800187 mSamplerTextures[TextureType::_2D].resize(caps.maxCombinedTextureImageUnits);
188 mSamplerTextures[TextureType::CubeMap].resize(caps.maxCombinedTextureImageUnits);
Geoff Langeb66a6e2016-10-31 13:06:12 -0400189 if (clientVersion >= Version(3, 0))
Shannon Woods53a94a82014-06-24 15:20:36 -0400190 {
Geoff Lang76b10c92014-09-05 16:28:14 -0400191 // TODO: These could also be enabled via extension
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800192 mSamplerTextures[TextureType::_2DArray].resize(caps.maxCombinedTextureImageUnits);
193 mSamplerTextures[TextureType::_3D].resize(caps.maxCombinedTextureImageUnits);
Shannon Woods53a94a82014-06-24 15:20:36 -0400194 }
Geoff Lang3b573612016-10-31 14:08:10 -0400195 if (clientVersion >= Version(3, 1))
196 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800197 mSamplerTextures[TextureType::_2DMultisample].resize(caps.maxCombinedTextureImageUnits);
Jiajia Qin6eafb042016-12-27 17:04:07 +0800198
199 mAtomicCounterBuffers.resize(caps.maxAtomicCounterBufferBindings);
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800200 mShaderStorageBuffers.resize(caps.maxShaderStorageBufferBindings);
Xinghua Cao65ec0b22017-03-28 16:10:52 +0800201 mImageUnits.resize(caps.maxImageUnits);
Geoff Lang3b573612016-10-31 14:08:10 -0400202 }
Geoff Lang4751aab2017-10-30 15:14:52 -0400203 if (nativeExtensions.textureRectangle)
Corentin Wallez13c0dd42017-07-04 18:27:01 -0400204 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800205 mSamplerTextures[TextureType::Rectangle].resize(caps.maxCombinedTextureImageUnits);
Corentin Wallez13c0dd42017-07-04 18:27:01 -0400206 }
Geoff Lang4751aab2017-10-30 15:14:52 -0400207 if (nativeExtensions.eglImageExternal || nativeExtensions.eglStreamConsumerExternal)
Ian Ewellbda75592016-04-18 17:25:54 -0400208 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800209 mSamplerTextures[TextureType::External].resize(caps.maxCombinedTextureImageUnits);
Ian Ewellbda75592016-04-18 17:25:54 -0400210 }
Jamie Madill81c2e252017-09-09 23:32:46 -0400211 mCompleteTextureCache.resize(caps.maxCombinedTextureImageUnits, nullptr);
212 mCompleteTextureBindings.reserve(caps.maxCombinedTextureImageUnits);
Geoff Lange51ba632017-11-21 11:45:25 -0500213 mCachedTexturesInitState = InitState::MayNeedInit;
Jamie Madill81c2e252017-09-09 23:32:46 -0400214 for (uint32_t textureIndex = 0; textureIndex < caps.maxCombinedTextureImageUnits;
215 ++textureIndex)
216 {
Jamie Madilld4442552018-02-27 22:03:47 -0500217 mCompleteTextureBindings.emplace_back(this, textureIndex);
Jamie Madill81c2e252017-09-09 23:32:46 -0400218 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400219
Geoff Lang76b10c92014-09-05 16:28:14 -0400220 mSamplers.resize(caps.maxCombinedTextureImageUnits);
Shannon Woods53a94a82014-06-24 15:20:36 -0400221
Corentin Wallezad3ae902018-03-09 13:40:42 -0500222 for (QueryType type : angle::AllEnums<QueryType>())
223 {
224 mActiveQueries[type].set(context, nullptr);
225 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400226
Ian Ewell3ffd78b2016-01-22 16:09:42 -0500227 mProgram = nullptr;
Shannon Woods53a94a82014-06-24 15:20:36 -0400228
Ian Ewell3ffd78b2016-01-22 16:09:42 -0500229 mReadFramebuffer = nullptr;
230 mDrawFramebuffer = nullptr;
Jamie Madillb4b53c52015-02-03 15:22:48 -0500231
232 mPrimitiveRestart = false;
Geoff Lang70d0f492015-12-10 17:45:46 -0500233
Geoff Lang70d0f492015-12-10 17:45:46 -0500234 mDebug.setMaxLoggedMessages(extensions.maxDebugLoggedMessages);
Sami Väisänen74c23472016-05-09 17:30:30 +0300235
Geoff Lang488130e2017-09-27 13:53:11 -0400236 mMultiSampling = true;
237 mSampleAlphaToOne = false;
Sami Väisänena797e062016-05-12 15:23:40 +0300238
239 mCoverageModulation = GL_NONE;
Sami Väisänene45e53b2016-05-25 10:36:04 +0300240
241 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixProj);
242 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixMV);
243 mPathStencilFunc = GL_ALWAYS;
244 mPathStencilRef = 0;
245 mPathStencilMask = std::numeric_limits<GLuint>::max();
Jamie Madille08a1d32017-03-07 17:24:06 -0500246
Lingfeng Yangdbb9c532018-02-25 19:58:24 -0800247 // GLES1 emulation: Initialize state for GLES1 if version
248 // applies
249 if (clientVersion < Version(2, 0))
250 {
Lingfeng Yange547aac2018-04-05 09:39:20 -0700251 mGLES1State.initialize(context, this);
Lingfeng Yangdbb9c532018-02-25 19:58:24 -0800252 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400253}
254
Jamie Madill6c1f6712017-02-14 19:08:04 -0500255void State::reset(const Context *context)
Shannon Woods53a94a82014-06-24 15:20:36 -0400256{
Jamie Madill8693bdb2017-09-02 15:32:14 -0400257 for (auto &bindingVec : mSamplerTextures)
Shannon Woods53a94a82014-06-24 15:20:36 -0400258 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800259 for (size_t textureIdx = 0; textureIdx < bindingVec.size(); textureIdx++)
Shannon Woods53a94a82014-06-24 15:20:36 -0400260 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800261 bindingVec[textureIdx].set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400262 }
263 }
Geoff Lang76b10c92014-09-05 16:28:14 -0400264 for (size_t samplerIdx = 0; samplerIdx < mSamplers.size(); samplerIdx++)
265 {
Jamie Madill4928b7c2017-06-20 12:57:39 -0400266 mSamplers[samplerIdx].set(context, nullptr);
Geoff Lang76b10c92014-09-05 16:28:14 -0400267 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400268
Xinghua Cao65ec0b22017-03-28 16:10:52 +0800269 for (auto &imageUnit : mImageUnits)
270 {
271 imageUnit.texture.set(context, nullptr);
272 imageUnit.level = 0;
273 imageUnit.layered = false;
274 imageUnit.layer = 0;
275 imageUnit.access = GL_READ_ONLY;
276 imageUnit.format = GL_R32UI;
277 }
278
Jamie Madill4928b7c2017-06-20 12:57:39 -0400279 mRenderbuffer.set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400280
Corentin Wallez336129f2017-10-17 15:55:40 -0400281 for (auto type : angle::AllEnums<BufferBinding>())
282 {
James Darpiniane8a93c62018-01-04 18:02:24 -0800283 UpdateBufferBinding(context, &mBoundBuffers[type], nullptr, type);
Corentin Wallez336129f2017-10-17 15:55:40 -0400284 }
285
Geoff Lang7dd2e102014-11-10 15:19:26 -0500286 if (mProgram)
287 {
Jamie Madill6c1f6712017-02-14 19:08:04 -0500288 mProgram->release(context);
Geoff Lang7dd2e102014-11-10 15:19:26 -0500289 }
Yunchao Hed7297bf2017-04-19 15:27:10 +0800290 mProgram = nullptr;
Geoff Lang7dd2e102014-11-10 15:19:26 -0500291
Yunchao Hea336b902017-08-02 16:05:21 +0800292 mProgramPipeline.set(context, nullptr);
293
James Darpiniane8a93c62018-01-04 18:02:24 -0800294 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -0400295 mTransformFeedback->onBindingChanged(context, false);
Jamie Madill4928b7c2017-06-20 12:57:39 -0400296 mTransformFeedback.set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400297
Corentin Wallezad3ae902018-03-09 13:40:42 -0500298 for (QueryType type : angle::AllEnums<QueryType>())
Shannon Woods53a94a82014-06-24 15:20:36 -0400299 {
Corentin Wallezad3ae902018-03-09 13:40:42 -0500300 mActiveQueries[type].set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400301 }
302
Corentin Wallez336129f2017-10-17 15:55:40 -0400303 for (auto &buf : mUniformBuffers)
Shannon Woods53a94a82014-06-24 15:20:36 -0400304 {
James Darpiniane8a93c62018-01-04 18:02:24 -0800305 UpdateBufferBinding(context, &buf, nullptr, BufferBinding::Uniform);
Shannon Woods53a94a82014-06-24 15:20:36 -0400306 }
307
Jiajia Qin6eafb042016-12-27 17:04:07 +0800308 for (auto &buf : mAtomicCounterBuffers)
309 {
James Darpiniane8a93c62018-01-04 18:02:24 -0800310 UpdateBufferBinding(context, &buf, nullptr, BufferBinding::AtomicCounter);
Jiajia Qin6eafb042016-12-27 17:04:07 +0800311 }
312
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800313 for (auto &buf : mShaderStorageBuffers)
314 {
James Darpiniane8a93c62018-01-04 18:02:24 -0800315 UpdateBufferBinding(context, &buf, nullptr, BufferBinding::ShaderStorage);
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800316 }
317
Sami Väisänene45e53b2016-05-25 10:36:04 +0300318 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixProj);
319 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixMV);
320 mPathStencilFunc = GL_ALWAYS;
321 mPathStencilRef = 0;
322 mPathStencilMask = std::numeric_limits<GLuint>::max();
323
Jamie Madill1b94d432015-08-07 13:23:23 -0400324 // TODO(jmadill): Is this necessary?
325 setAllDirtyBits();
Shannon Woods53a94a82014-06-24 15:20:36 -0400326}
327
328const RasterizerState &State::getRasterizerState() const
329{
330 return mRasterizer;
331}
332
333const BlendState &State::getBlendState() const
334{
335 return mBlend;
336}
337
338const DepthStencilState &State::getDepthStencilState() const
339{
340 return mDepthStencil;
341}
342
Jamie Madillf75ab352015-03-16 10:46:52 -0400343void State::setColorClearValue(float red, float green, float blue, float alpha)
Shannon Woods53a94a82014-06-24 15:20:36 -0400344{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700345 mColorClearValue.red = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400346 mColorClearValue.green = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700347 mColorClearValue.blue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400348 mColorClearValue.alpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400349 mDirtyBits.set(DIRTY_BIT_CLEAR_COLOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400350}
351
Jamie Madillf75ab352015-03-16 10:46:52 -0400352void State::setDepthClearValue(float depth)
Shannon Woods53a94a82014-06-24 15:20:36 -0400353{
354 mDepthClearValue = depth;
Jamie Madill1b94d432015-08-07 13:23:23 -0400355 mDirtyBits.set(DIRTY_BIT_CLEAR_DEPTH);
Shannon Woods53a94a82014-06-24 15:20:36 -0400356}
357
Jamie Madillf75ab352015-03-16 10:46:52 -0400358void State::setStencilClearValue(int stencil)
Shannon Woods53a94a82014-06-24 15:20:36 -0400359{
360 mStencilClearValue = stencil;
Jamie Madill1b94d432015-08-07 13:23:23 -0400361 mDirtyBits.set(DIRTY_BIT_CLEAR_STENCIL);
Shannon Woods53a94a82014-06-24 15:20:36 -0400362}
363
Shannon Woods53a94a82014-06-24 15:20:36 -0400364void State::setColorMask(bool red, bool green, bool blue, bool alpha)
365{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700366 mBlend.colorMaskRed = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400367 mBlend.colorMaskGreen = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700368 mBlend.colorMaskBlue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400369 mBlend.colorMaskAlpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400370 mDirtyBits.set(DIRTY_BIT_COLOR_MASK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400371}
372
373void State::setDepthMask(bool mask)
374{
375 mDepthStencil.depthMask = mask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400376 mDirtyBits.set(DIRTY_BIT_DEPTH_MASK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400377}
378
379bool State::isRasterizerDiscardEnabled() const
380{
381 return mRasterizer.rasterizerDiscard;
382}
383
384void State::setRasterizerDiscard(bool enabled)
385{
386 mRasterizer.rasterizerDiscard = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400387 mDirtyBits.set(DIRTY_BIT_RASTERIZER_DISCARD_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400388}
389
390bool State::isCullFaceEnabled() const
391{
392 return mRasterizer.cullFace;
393}
394
395void State::setCullFace(bool enabled)
396{
397 mRasterizer.cullFace = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400398 mDirtyBits.set(DIRTY_BIT_CULL_FACE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400399}
400
Corentin Wallez2e568cf2017-09-18 17:05:22 -0400401void State::setCullMode(CullFaceMode mode)
Shannon Woods53a94a82014-06-24 15:20:36 -0400402{
403 mRasterizer.cullMode = mode;
Jamie Madill1b94d432015-08-07 13:23:23 -0400404 mDirtyBits.set(DIRTY_BIT_CULL_FACE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400405}
406
407void State::setFrontFace(GLenum front)
408{
409 mRasterizer.frontFace = front;
Jamie Madill1b94d432015-08-07 13:23:23 -0400410 mDirtyBits.set(DIRTY_BIT_FRONT_FACE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400411}
412
413bool State::isDepthTestEnabled() const
414{
415 return mDepthStencil.depthTest;
416}
417
418void State::setDepthTest(bool enabled)
419{
420 mDepthStencil.depthTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400421 mDirtyBits.set(DIRTY_BIT_DEPTH_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400422}
423
424void State::setDepthFunc(GLenum depthFunc)
425{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700426 mDepthStencil.depthFunc = depthFunc;
427 mDirtyBits.set(DIRTY_BIT_DEPTH_FUNC);
Shannon Woods53a94a82014-06-24 15:20:36 -0400428}
429
430void State::setDepthRange(float zNear, float zFar)
431{
432 mNearZ = zNear;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700433 mFarZ = zFar;
Jamie Madill1b94d432015-08-07 13:23:23 -0400434 mDirtyBits.set(DIRTY_BIT_DEPTH_RANGE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400435}
436
Geoff Langd42f5b82015-04-16 14:03:29 -0400437float State::getNearPlane() const
Shannon Woods53a94a82014-06-24 15:20:36 -0400438{
Geoff Langd42f5b82015-04-16 14:03:29 -0400439 return mNearZ;
440}
441
442float State::getFarPlane() const
443{
444 return mFarZ;
Shannon Woods53a94a82014-06-24 15:20:36 -0400445}
446
447bool State::isBlendEnabled() const
448{
449 return mBlend.blend;
450}
451
452void State::setBlend(bool enabled)
453{
454 mBlend.blend = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400455 mDirtyBits.set(DIRTY_BIT_BLEND_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400456}
457
458void State::setBlendFactors(GLenum sourceRGB, GLenum destRGB, GLenum sourceAlpha, GLenum destAlpha)
459{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700460 mBlend.sourceBlendRGB = sourceRGB;
461 mBlend.destBlendRGB = destRGB;
Shannon Woods53a94a82014-06-24 15:20:36 -0400462 mBlend.sourceBlendAlpha = sourceAlpha;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700463 mBlend.destBlendAlpha = destAlpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400464 mDirtyBits.set(DIRTY_BIT_BLEND_FUNCS);
Shannon Woods53a94a82014-06-24 15:20:36 -0400465}
466
467void State::setBlendColor(float red, float green, float blue, float alpha)
468{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700469 mBlendColor.red = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400470 mBlendColor.green = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700471 mBlendColor.blue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400472 mBlendColor.alpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400473 mDirtyBits.set(DIRTY_BIT_BLEND_COLOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400474}
475
476void State::setBlendEquation(GLenum rgbEquation, GLenum alphaEquation)
477{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700478 mBlend.blendEquationRGB = rgbEquation;
Shannon Woods53a94a82014-06-24 15:20:36 -0400479 mBlend.blendEquationAlpha = alphaEquation;
Jamie Madill1b94d432015-08-07 13:23:23 -0400480 mDirtyBits.set(DIRTY_BIT_BLEND_EQUATIONS);
Shannon Woods53a94a82014-06-24 15:20:36 -0400481}
482
483const ColorF &State::getBlendColor() const
484{
485 return mBlendColor;
486}
487
488bool State::isStencilTestEnabled() const
489{
490 return mDepthStencil.stencilTest;
491}
492
493void State::setStencilTest(bool enabled)
494{
495 mDepthStencil.stencilTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400496 mDirtyBits.set(DIRTY_BIT_STENCIL_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400497}
498
499void State::setStencilParams(GLenum stencilFunc, GLint stencilRef, GLuint stencilMask)
500{
501 mDepthStencil.stencilFunc = stencilFunc;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700502 mStencilRef = (stencilRef > 0) ? stencilRef : 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400503 mDepthStencil.stencilMask = stencilMask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400504 mDirtyBits.set(DIRTY_BIT_STENCIL_FUNCS_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400505}
506
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700507void State::setStencilBackParams(GLenum stencilBackFunc,
508 GLint stencilBackRef,
509 GLuint stencilBackMask)
Shannon Woods53a94a82014-06-24 15:20:36 -0400510{
511 mDepthStencil.stencilBackFunc = stencilBackFunc;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700512 mStencilBackRef = (stencilBackRef > 0) ? stencilBackRef : 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400513 mDepthStencil.stencilBackMask = stencilBackMask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400514 mDirtyBits.set(DIRTY_BIT_STENCIL_FUNCS_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400515}
516
517void State::setStencilWritemask(GLuint stencilWritemask)
518{
519 mDepthStencil.stencilWritemask = stencilWritemask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400520 mDirtyBits.set(DIRTY_BIT_STENCIL_WRITEMASK_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400521}
522
523void State::setStencilBackWritemask(GLuint stencilBackWritemask)
524{
525 mDepthStencil.stencilBackWritemask = stencilBackWritemask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400526 mDirtyBits.set(DIRTY_BIT_STENCIL_WRITEMASK_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400527}
528
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700529void State::setStencilOperations(GLenum stencilFail,
530 GLenum stencilPassDepthFail,
531 GLenum stencilPassDepthPass)
Shannon Woods53a94a82014-06-24 15:20:36 -0400532{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700533 mDepthStencil.stencilFail = stencilFail;
Shannon Woods53a94a82014-06-24 15:20:36 -0400534 mDepthStencil.stencilPassDepthFail = stencilPassDepthFail;
535 mDepthStencil.stencilPassDepthPass = stencilPassDepthPass;
Jamie Madill1b94d432015-08-07 13:23:23 -0400536 mDirtyBits.set(DIRTY_BIT_STENCIL_OPS_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400537}
538
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700539void State::setStencilBackOperations(GLenum stencilBackFail,
540 GLenum stencilBackPassDepthFail,
541 GLenum stencilBackPassDepthPass)
Shannon Woods53a94a82014-06-24 15:20:36 -0400542{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700543 mDepthStencil.stencilBackFail = stencilBackFail;
Shannon Woods53a94a82014-06-24 15:20:36 -0400544 mDepthStencil.stencilBackPassDepthFail = stencilBackPassDepthFail;
545 mDepthStencil.stencilBackPassDepthPass = stencilBackPassDepthPass;
Jamie Madill1b94d432015-08-07 13:23:23 -0400546 mDirtyBits.set(DIRTY_BIT_STENCIL_OPS_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400547}
548
549GLint State::getStencilRef() const
550{
551 return mStencilRef;
552}
553
554GLint State::getStencilBackRef() const
555{
556 return mStencilBackRef;
557}
558
559bool State::isPolygonOffsetFillEnabled() const
560{
561 return mRasterizer.polygonOffsetFill;
562}
563
564void State::setPolygonOffsetFill(bool enabled)
565{
Jamie Madill1b94d432015-08-07 13:23:23 -0400566 mRasterizer.polygonOffsetFill = enabled;
567 mDirtyBits.set(DIRTY_BIT_POLYGON_OFFSET_FILL_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400568}
569
570void State::setPolygonOffsetParams(GLfloat factor, GLfloat units)
571{
572 // An application can pass NaN values here, so handle this gracefully
573 mRasterizer.polygonOffsetFactor = factor != factor ? 0.0f : factor;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700574 mRasterizer.polygonOffsetUnits = units != units ? 0.0f : units;
Jamie Madill1b94d432015-08-07 13:23:23 -0400575 mDirtyBits.set(DIRTY_BIT_POLYGON_OFFSET);
Shannon Woods53a94a82014-06-24 15:20:36 -0400576}
577
578bool State::isSampleAlphaToCoverageEnabled() const
579{
580 return mBlend.sampleAlphaToCoverage;
581}
582
583void State::setSampleAlphaToCoverage(bool enabled)
584{
585 mBlend.sampleAlphaToCoverage = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400586 mDirtyBits.set(DIRTY_BIT_SAMPLE_ALPHA_TO_COVERAGE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400587}
588
589bool State::isSampleCoverageEnabled() const
590{
591 return mSampleCoverage;
592}
593
594void State::setSampleCoverage(bool enabled)
595{
596 mSampleCoverage = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400597 mDirtyBits.set(DIRTY_BIT_SAMPLE_COVERAGE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400598}
599
600void State::setSampleCoverageParams(GLclampf value, bool invert)
601{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700602 mSampleCoverageValue = value;
Shannon Woods53a94a82014-06-24 15:20:36 -0400603 mSampleCoverageInvert = invert;
Jamie Madill1b94d432015-08-07 13:23:23 -0400604 mDirtyBits.set(DIRTY_BIT_SAMPLE_COVERAGE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400605}
606
Geoff Lang0fbb6002015-04-16 11:11:53 -0400607GLclampf State::getSampleCoverageValue() const
Shannon Woods53a94a82014-06-24 15:20:36 -0400608{
Geoff Lang0fbb6002015-04-16 11:11:53 -0400609 return mSampleCoverageValue;
610}
Shannon Woods53a94a82014-06-24 15:20:36 -0400611
Geoff Lang0fbb6002015-04-16 11:11:53 -0400612bool State::getSampleCoverageInvert() const
613{
614 return mSampleCoverageInvert;
Shannon Woods53a94a82014-06-24 15:20:36 -0400615}
616
Jiawei Shaodb342272017-09-27 10:21:45 +0800617bool State::isSampleMaskEnabled() const
618{
619 return mSampleMask;
620}
621
622void State::setSampleMaskEnabled(bool enabled)
623{
624 mSampleMask = enabled;
625 mDirtyBits.set(DIRTY_BIT_SAMPLE_MASK_ENABLED);
626}
627
628void State::setSampleMaskParams(GLuint maskNumber, GLbitfield mask)
629{
630 ASSERT(maskNumber < mMaxSampleMaskWords);
631 mSampleMaskValues[maskNumber] = mask;
Jamie Madillc67323a2017-11-02 23:11:41 -0400632 // TODO(jmadill): Use a child dirty bit if we ever use more than two words.
633 mDirtyBits.set(DIRTY_BIT_SAMPLE_MASK);
Jiawei Shaodb342272017-09-27 10:21:45 +0800634}
635
636GLbitfield State::getSampleMaskWord(GLuint maskNumber) const
637{
638 ASSERT(maskNumber < mMaxSampleMaskWords);
639 return mSampleMaskValues[maskNumber];
640}
641
642GLuint State::getMaxSampleMaskWords() const
643{
644 return mMaxSampleMaskWords;
645}
646
Sami Väisänen74c23472016-05-09 17:30:30 +0300647void State::setSampleAlphaToOne(bool enabled)
648{
649 mSampleAlphaToOne = enabled;
650 mDirtyBits.set(DIRTY_BIT_SAMPLE_ALPHA_TO_ONE);
651}
652
653bool State::isSampleAlphaToOneEnabled() const
654{
655 return mSampleAlphaToOne;
656}
657
658void State::setMultisampling(bool enabled)
659{
660 mMultiSampling = enabled;
661 mDirtyBits.set(DIRTY_BIT_MULTISAMPLING);
662}
663
664bool State::isMultisamplingEnabled() const
665{
666 return mMultiSampling;
667}
668
Shannon Woods53a94a82014-06-24 15:20:36 -0400669bool State::isScissorTestEnabled() const
670{
671 return mScissorTest;
672}
673
674void State::setScissorTest(bool enabled)
675{
676 mScissorTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400677 mDirtyBits.set(DIRTY_BIT_SCISSOR_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400678}
679
680void State::setScissorParams(GLint x, GLint y, GLsizei width, GLsizei height)
681{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700682 mScissor.x = x;
683 mScissor.y = y;
684 mScissor.width = width;
Shannon Woods53a94a82014-06-24 15:20:36 -0400685 mScissor.height = height;
Jamie Madill1b94d432015-08-07 13:23:23 -0400686 mDirtyBits.set(DIRTY_BIT_SCISSOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400687}
688
689const Rectangle &State::getScissor() const
690{
691 return mScissor;
692}
693
694bool State::isDitherEnabled() const
695{
696 return mBlend.dither;
697}
698
699void State::setDither(bool enabled)
700{
701 mBlend.dither = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400702 mDirtyBits.set(DIRTY_BIT_DITHER_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400703}
704
Jamie Madillb4b53c52015-02-03 15:22:48 -0500705bool State::isPrimitiveRestartEnabled() const
706{
707 return mPrimitiveRestart;
708}
709
710void State::setPrimitiveRestart(bool enabled)
711{
712 mPrimitiveRestart = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400713 mDirtyBits.set(DIRTY_BIT_PRIMITIVE_RESTART_ENABLED);
Jamie Madillb4b53c52015-02-03 15:22:48 -0500714}
715
Shannon Woods53a94a82014-06-24 15:20:36 -0400716void State::setEnableFeature(GLenum feature, bool enabled)
717{
718 switch (feature)
719 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700720 case GL_MULTISAMPLE_EXT:
721 setMultisampling(enabled);
722 break;
723 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
724 setSampleAlphaToOne(enabled);
725 break;
726 case GL_CULL_FACE:
727 setCullFace(enabled);
728 break;
729 case GL_POLYGON_OFFSET_FILL:
730 setPolygonOffsetFill(enabled);
731 break;
732 case GL_SAMPLE_ALPHA_TO_COVERAGE:
733 setSampleAlphaToCoverage(enabled);
734 break;
735 case GL_SAMPLE_COVERAGE:
736 setSampleCoverage(enabled);
737 break;
738 case GL_SCISSOR_TEST:
739 setScissorTest(enabled);
740 break;
741 case GL_STENCIL_TEST:
742 setStencilTest(enabled);
743 break;
744 case GL_DEPTH_TEST:
745 setDepthTest(enabled);
746 break;
747 case GL_BLEND:
748 setBlend(enabled);
749 break;
750 case GL_DITHER:
751 setDither(enabled);
752 break;
753 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
754 setPrimitiveRestart(enabled);
755 break;
756 case GL_RASTERIZER_DISCARD:
757 setRasterizerDiscard(enabled);
758 break;
759 case GL_SAMPLE_MASK:
760 setSampleMaskEnabled(enabled);
761 break;
762 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
763 mDebug.setOutputSynchronous(enabled);
764 break;
765 case GL_DEBUG_OUTPUT:
766 mDebug.setOutputEnabled(enabled);
767 break;
768 case GL_FRAMEBUFFER_SRGB_EXT:
769 setFramebufferSRGB(enabled);
770 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -0700771
772 // GLES1 emulation
773 case GL_ALPHA_TEST:
774 mGLES1State.mAlphaTestEnabled = enabled;
775 break;
Lingfeng Yang23dc90b2018-04-23 09:01:49 -0700776 case GL_TEXTURE_2D:
777 mGLES1State.mTexUnitEnables[mActiveSampler].set(TextureType::_2D, enabled);
778 break;
779 case GL_TEXTURE_CUBE_MAP:
780 mGLES1State.mTexUnitEnables[mActiveSampler].set(TextureType::CubeMap, enabled);
781 break;
Lingfeng Yangd0febe72018-05-17 22:36:52 -0700782 case GL_LIGHTING:
783 mGLES1State.mLightingEnabled = enabled;
784 break;
785 case GL_LIGHT0:
786 case GL_LIGHT1:
787 case GL_LIGHT2:
788 case GL_LIGHT3:
789 case GL_LIGHT4:
790 case GL_LIGHT5:
791 case GL_LIGHT6:
792 case GL_LIGHT7:
793 mGLES1State.mLights[feature - GL_LIGHT0].enabled = enabled;
794 break;
795 case GL_NORMALIZE:
796 mGLES1State.mNormalizeEnabled = enabled;
797 break;
798 case GL_RESCALE_NORMAL:
799 mGLES1State.mRescaleNormalEnabled = enabled;
800 break;
801 case GL_COLOR_MATERIAL:
802 mGLES1State.mColorMaterialEnabled = enabled;
803 break;
Lingfeng Yang060088a2018-05-30 20:40:57 -0700804 case GL_CLIP_PLANE0:
805 case GL_CLIP_PLANE1:
806 case GL_CLIP_PLANE2:
807 case GL_CLIP_PLANE3:
808 case GL_CLIP_PLANE4:
809 case GL_CLIP_PLANE5:
810 mGLES1State.mClipPlanes[feature - GL_CLIP_PLANE0].enabled = enabled;
811 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700812 default:
813 UNREACHABLE();
Shannon Woods53a94a82014-06-24 15:20:36 -0400814 }
815}
816
Jamie Madilldfde6ab2016-06-09 07:07:18 -0700817bool State::getEnableFeature(GLenum feature) const
Shannon Woods53a94a82014-06-24 15:20:36 -0400818{
819 switch (feature)
820 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700821 case GL_MULTISAMPLE_EXT:
822 return isMultisamplingEnabled();
823 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
824 return isSampleAlphaToOneEnabled();
825 case GL_CULL_FACE:
826 return isCullFaceEnabled();
827 case GL_POLYGON_OFFSET_FILL:
828 return isPolygonOffsetFillEnabled();
829 case GL_SAMPLE_ALPHA_TO_COVERAGE:
830 return isSampleAlphaToCoverageEnabled();
831 case GL_SAMPLE_COVERAGE:
832 return isSampleCoverageEnabled();
833 case GL_SCISSOR_TEST:
834 return isScissorTestEnabled();
835 case GL_STENCIL_TEST:
836 return isStencilTestEnabled();
837 case GL_DEPTH_TEST:
838 return isDepthTestEnabled();
839 case GL_BLEND:
840 return isBlendEnabled();
841 case GL_DITHER:
842 return isDitherEnabled();
843 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
844 return isPrimitiveRestartEnabled();
845 case GL_RASTERIZER_DISCARD:
846 return isRasterizerDiscardEnabled();
847 case GL_SAMPLE_MASK:
848 return isSampleMaskEnabled();
849 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
850 return mDebug.isOutputSynchronous();
851 case GL_DEBUG_OUTPUT:
852 return mDebug.isOutputEnabled();
853 case GL_BIND_GENERATES_RESOURCE_CHROMIUM:
854 return isBindGeneratesResourceEnabled();
855 case GL_CLIENT_ARRAYS_ANGLE:
856 return areClientArraysEnabled();
857 case GL_FRAMEBUFFER_SRGB_EXT:
858 return getFramebufferSRGB();
859 case GL_ROBUST_RESOURCE_INITIALIZATION_ANGLE:
860 return mRobustResourceInit;
861 case GL_PROGRAM_CACHE_ENABLED_ANGLE:
862 return mProgramBinaryCacheEnabled;
Jamie Madillc43be722017-07-13 16:22:14 -0400863
Lingfeng Yang13b708f2018-03-21 12:14:10 -0700864 // GLES1 emulation
865 case GL_ALPHA_TEST:
866 return mGLES1State.mAlphaTestEnabled;
Lingfeng Yang01074432018-04-16 10:19:51 -0700867 case GL_VERTEX_ARRAY:
868 return mGLES1State.mVertexArrayEnabled;
869 case GL_NORMAL_ARRAY:
870 return mGLES1State.mNormalArrayEnabled;
871 case GL_COLOR_ARRAY:
872 return mGLES1State.mColorArrayEnabled;
873 case GL_POINT_SIZE_ARRAY_OES:
874 return mGLES1State.mPointSizeArrayEnabled;
875 case GL_TEXTURE_COORD_ARRAY:
876 return mGLES1State.mTexCoordArrayEnabled[mGLES1State.mClientActiveTexture];
Lingfeng Yang23dc90b2018-04-23 09:01:49 -0700877 case GL_TEXTURE_2D:
878 return mGLES1State.mTexUnitEnables[mActiveSampler].test(TextureType::_2D);
879 case GL_TEXTURE_CUBE_MAP:
880 return mGLES1State.mTexUnitEnables[mActiveSampler].test(TextureType::CubeMap);
Lingfeng Yangd0febe72018-05-17 22:36:52 -0700881 case GL_LIGHTING:
882 return mGLES1State.mLightingEnabled;
883 case GL_LIGHT0:
884 case GL_LIGHT1:
885 case GL_LIGHT2:
886 case GL_LIGHT3:
887 case GL_LIGHT4:
888 case GL_LIGHT5:
889 case GL_LIGHT6:
890 case GL_LIGHT7:
891 return mGLES1State.mLights[feature - GL_LIGHT0].enabled;
892 case GL_NORMALIZE:
893 return mGLES1State.mNormalizeEnabled;
894 case GL_RESCALE_NORMAL:
895 return mGLES1State.mRescaleNormalEnabled;
896 case GL_COLOR_MATERIAL:
897 return mGLES1State.mColorMaterialEnabled;
Lingfeng Yang060088a2018-05-30 20:40:57 -0700898 case GL_CLIP_PLANE0:
899 case GL_CLIP_PLANE1:
900 case GL_CLIP_PLANE2:
901 case GL_CLIP_PLANE3:
902 case GL_CLIP_PLANE4:
903 case GL_CLIP_PLANE5:
904 return mGLES1State.mClipPlanes[feature - GL_CLIP_PLANE0].enabled;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700905 default:
906 UNREACHABLE();
907 return false;
Shannon Woods53a94a82014-06-24 15:20:36 -0400908 }
909}
910
911void State::setLineWidth(GLfloat width)
912{
913 mLineWidth = width;
Jamie Madill1b94d432015-08-07 13:23:23 -0400914 mDirtyBits.set(DIRTY_BIT_LINE_WIDTH);
Shannon Woods53a94a82014-06-24 15:20:36 -0400915}
916
Geoff Lang4b3f4162015-04-16 13:22:05 -0400917float State::getLineWidth() const
918{
919 return mLineWidth;
920}
921
Shannon Woods53a94a82014-06-24 15:20:36 -0400922void State::setGenerateMipmapHint(GLenum hint)
923{
924 mGenerateMipmapHint = hint;
Jamie Madill1b94d432015-08-07 13:23:23 -0400925 mDirtyBits.set(DIRTY_BIT_GENERATE_MIPMAP_HINT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400926}
927
928void State::setFragmentShaderDerivativeHint(GLenum hint)
929{
930 mFragmentShaderDerivativeHint = hint;
Jamie Madill1b94d432015-08-07 13:23:23 -0400931 mDirtyBits.set(DIRTY_BIT_SHADER_DERIVATIVE_HINT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400932 // TODO: Propagate the hint to shader translator so we can write
933 // ddx, ddx_coarse, or ddx_fine depending on the hint.
934 // Ignore for now. It is valid for implementations to ignore hint.
935}
936
Geoff Langf41a7152016-09-19 15:11:17 -0400937bool State::isBindGeneratesResourceEnabled() const
938{
939 return mBindGeneratesResource;
940}
941
Geoff Langfeb8c682017-02-13 16:07:35 -0500942bool State::areClientArraysEnabled() const
943{
944 return mClientArraysEnabled;
945}
946
Shannon Woods53a94a82014-06-24 15:20:36 -0400947void State::setViewportParams(GLint x, GLint y, GLsizei width, GLsizei height)
948{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700949 mViewport.x = x;
950 mViewport.y = y;
951 mViewport.width = width;
Shannon Woods53a94a82014-06-24 15:20:36 -0400952 mViewport.height = height;
Jamie Madill1b94d432015-08-07 13:23:23 -0400953 mDirtyBits.set(DIRTY_BIT_VIEWPORT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400954}
955
956const Rectangle &State::getViewport() const
957{
958 return mViewport;
959}
960
961void State::setActiveSampler(unsigned int active)
962{
963 mActiveSampler = active;
964}
965
966unsigned int State::getActiveSampler() const
967{
Cooper Partin4d61f7e2015-08-12 10:56:50 -0700968 return static_cast<unsigned int>(mActiveSampler);
Shannon Woods53a94a82014-06-24 15:20:36 -0400969}
970
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800971void State::setSamplerTexture(const Context *context, TextureType type, Texture *texture)
Shannon Woods53a94a82014-06-24 15:20:36 -0400972{
Jamie Madill4928b7c2017-06-20 12:57:39 -0400973 mSamplerTextures[type][mActiveSampler].set(context, texture);
Jamie Madill81c2e252017-09-09 23:32:46 -0400974 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
975 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Shannon Woods53a94a82014-06-24 15:20:36 -0400976}
977
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800978Texture *State::getTargetTexture(TextureType type) const
Jamie Madillc29968b2016-01-20 11:17:23 -0500979{
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800980 return getSamplerTexture(static_cast<unsigned int>(mActiveSampler), type);
Jamie Madillc29968b2016-01-20 11:17:23 -0500981}
982
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800983Texture *State::getSamplerTexture(unsigned int sampler, TextureType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -0400984{
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800985 ASSERT(sampler < mSamplerTextures[type].size());
986 return mSamplerTextures[type][sampler].get();
Shannon Woods53a94a82014-06-24 15:20:36 -0400987}
988
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800989GLuint State::getSamplerTextureId(unsigned int sampler, TextureType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -0400990{
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800991 ASSERT(sampler < mSamplerTextures[type].size());
992 return mSamplerTextures[type][sampler].id();
Shannon Woods53a94a82014-06-24 15:20:36 -0400993}
994
Jamie Madilla02315b2017-02-23 14:14:47 -0500995void State::detachTexture(const Context *context, const TextureMap &zeroTextures, GLuint texture)
Shannon Woods53a94a82014-06-24 15:20:36 -0400996{
997 // Textures have a detach method on State rather than a simple
998 // removeBinding, because the zero/null texture objects are managed
999 // separately, and don't have to go through the Context's maps or
1000 // the ResourceManager.
1001
1002 // [OpenGL ES 2.0.24] section 3.8 page 84:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001003 // If a texture object is deleted, it is as if all texture units which are bound to that texture
1004 // object are rebound to texture object zero
Shannon Woods53a94a82014-06-24 15:20:36 -04001005
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001006 for (TextureType type : angle::AllEnums<TextureType>())
Shannon Woods53a94a82014-06-24 15:20:36 -04001007 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001008 TextureBindingVector &textureVector = mSamplerTextures[type];
Jamie Madill81c2e252017-09-09 23:32:46 -04001009 for (BindingPointer<Texture> &binding : textureVector)
Shannon Woods53a94a82014-06-24 15:20:36 -04001010 {
Geoff Lang76b10c92014-09-05 16:28:14 -04001011 if (binding.id() == texture)
Shannon Woods53a94a82014-06-24 15:20:36 -04001012 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001013 Texture *zeroTexture = zeroTextures[type].get();
1014 ASSERT(zeroTexture != nullptr);
Jamie Madille6382c32014-11-07 15:05:26 -05001015 // Zero textures are the "default" textures instead of NULL
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001016 binding.set(context, zeroTexture);
Jamie Madill81c2e252017-09-09 23:32:46 -04001017 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
Shannon Woods53a94a82014-06-24 15:20:36 -04001018 }
1019 }
1020 }
1021
Xinghua Cao65ec0b22017-03-28 16:10:52 +08001022 for (auto &bindingImageUnit : mImageUnits)
1023 {
1024 if (bindingImageUnit.texture.id() == texture)
1025 {
1026 bindingImageUnit.texture.set(context, nullptr);
1027 bindingImageUnit.level = 0;
1028 bindingImageUnit.layered = false;
1029 bindingImageUnit.layer = 0;
1030 bindingImageUnit.access = GL_READ_ONLY;
1031 bindingImageUnit.format = GL_R32UI;
1032 break;
1033 }
1034 }
1035
Shannon Woods53a94a82014-06-24 15:20:36 -04001036 // [OpenGL ES 2.0.24] section 4.4 page 112:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001037 // If a texture object is deleted while its image is attached to the currently bound
1038 // framebuffer, then it is as if Texture2DAttachment had been called, with a texture of 0, for
1039 // each attachment point to which this image was attached in the currently bound framebuffer.
Shannon Woods53a94a82014-06-24 15:20:36 -04001040
Jamie Madill8693bdb2017-09-02 15:32:14 -04001041 if (mReadFramebuffer && mReadFramebuffer->detachTexture(context, texture))
Shannon Woods53a94a82014-06-24 15:20:36 -04001042 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001043 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
Shannon Woods53a94a82014-06-24 15:20:36 -04001044 }
1045
Jamie Madill8693bdb2017-09-02 15:32:14 -04001046 if (mDrawFramebuffer && mDrawFramebuffer->detachTexture(context, texture))
Shannon Woods53a94a82014-06-24 15:20:36 -04001047 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001048 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
Shannon Woods53a94a82014-06-24 15:20:36 -04001049 }
1050}
1051
Jamie Madill4928b7c2017-06-20 12:57:39 -04001052void State::initializeZeroTextures(const Context *context, const TextureMap &zeroTextures)
Jamie Madille6382c32014-11-07 15:05:26 -05001053{
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001054 for (TextureType type : angle::AllEnums<TextureType>())
Jamie Madille6382c32014-11-07 15:05:26 -05001055 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001056 for (size_t textureUnit = 0; textureUnit < mSamplerTextures[type].size(); ++textureUnit)
Jamie Madille6382c32014-11-07 15:05:26 -05001057 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001058 mSamplerTextures[type][textureUnit].set(context, zeroTextures[type].get());
Jamie Madille6382c32014-11-07 15:05:26 -05001059 }
1060 }
1061}
1062
Jamie Madill4928b7c2017-06-20 12:57:39 -04001063void State::setSamplerBinding(const Context *context, GLuint textureUnit, Sampler *sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001064{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001065 mSamplers[textureUnit].set(context, sampler);
Jamie Madill81c2e252017-09-09 23:32:46 -04001066 mDirtyBits.set(DIRTY_BIT_SAMPLER_BINDINGS);
1067 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Shannon Woods53a94a82014-06-24 15:20:36 -04001068}
1069
1070GLuint State::getSamplerId(GLuint textureUnit) const
1071{
Geoff Lang76b10c92014-09-05 16:28:14 -04001072 ASSERT(textureUnit < mSamplers.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001073 return mSamplers[textureUnit].id();
1074}
1075
1076Sampler *State::getSampler(GLuint textureUnit) const
1077{
1078 return mSamplers[textureUnit].get();
1079}
1080
Jamie Madill4928b7c2017-06-20 12:57:39 -04001081void State::detachSampler(const Context *context, GLuint sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001082{
1083 // [OpenGL ES 3.0.2] section 3.8.2 pages 123-124:
1084 // If a sampler object that is currently bound to one or more texture units is
1085 // deleted, it is as though BindSampler is called once for each texture unit to
1086 // which the sampler is bound, with unit set to the texture unit and sampler set to zero.
Jamie Madill81c2e252017-09-09 23:32:46 -04001087 for (BindingPointer<Sampler> &samplerBinding : mSamplers)
Shannon Woods53a94a82014-06-24 15:20:36 -04001088 {
Geoff Lang76b10c92014-09-05 16:28:14 -04001089 if (samplerBinding.id() == sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001090 {
Jamie Madill4928b7c2017-06-20 12:57:39 -04001091 samplerBinding.set(context, nullptr);
Jamie Madill81c2e252017-09-09 23:32:46 -04001092 mDirtyBits.set(DIRTY_BIT_SAMPLER_BINDINGS);
Shannon Woods53a94a82014-06-24 15:20:36 -04001093 }
1094 }
1095}
1096
Jamie Madill4928b7c2017-06-20 12:57:39 -04001097void State::setRenderbufferBinding(const Context *context, Renderbuffer *renderbuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001098{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001099 mRenderbuffer.set(context, renderbuffer);
Jamie Madill8693bdb2017-09-02 15:32:14 -04001100 mDirtyBits.set(DIRTY_BIT_RENDERBUFFER_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001101}
1102
1103GLuint State::getRenderbufferId() const
1104{
1105 return mRenderbuffer.id();
1106}
1107
Jamie Madilldfde6ab2016-06-09 07:07:18 -07001108Renderbuffer *State::getCurrentRenderbuffer() const
Shannon Woods53a94a82014-06-24 15:20:36 -04001109{
1110 return mRenderbuffer.get();
1111}
1112
Jamie Madilla02315b2017-02-23 14:14:47 -05001113void State::detachRenderbuffer(const Context *context, GLuint renderbuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001114{
1115 // [OpenGL ES 2.0.24] section 4.4 page 109:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001116 // If a renderbuffer that is currently bound to RENDERBUFFER is deleted, it is as though
1117 // BindRenderbuffer had been executed with the target RENDERBUFFER and name of zero.
Shannon Woods53a94a82014-06-24 15:20:36 -04001118
1119 if (mRenderbuffer.id() == renderbuffer)
1120 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001121 setRenderbufferBinding(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001122 }
1123
1124 // [OpenGL ES 2.0.24] section 4.4 page 111:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001125 // If a renderbuffer object is deleted while its image is attached to the currently bound
1126 // framebuffer, then it is as if FramebufferRenderbuffer had been called, with a renderbuffer of
1127 // 0, for each attachment point to which this image was attached in the currently bound
1128 // framebuffer.
Shannon Woods53a94a82014-06-24 15:20:36 -04001129
1130 Framebuffer *readFramebuffer = mReadFramebuffer;
1131 Framebuffer *drawFramebuffer = mDrawFramebuffer;
1132
Jamie Madill8693bdb2017-09-02 15:32:14 -04001133 if (readFramebuffer && readFramebuffer->detachRenderbuffer(context, renderbuffer))
Shannon Woods53a94a82014-06-24 15:20:36 -04001134 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001135 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
Shannon Woods53a94a82014-06-24 15:20:36 -04001136 }
1137
1138 if (drawFramebuffer && drawFramebuffer != readFramebuffer)
1139 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001140 if (drawFramebuffer->detachRenderbuffer(context, renderbuffer))
1141 {
1142 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
1143 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001144 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001145}
1146
1147void State::setReadFramebufferBinding(Framebuffer *framebuffer)
1148{
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001149 if (mReadFramebuffer == framebuffer)
1150 return;
1151
Shannon Woods53a94a82014-06-24 15:20:36 -04001152 mReadFramebuffer = framebuffer;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001153 mDirtyBits.set(DIRTY_BIT_READ_FRAMEBUFFER_BINDING);
1154
1155 if (mReadFramebuffer && mReadFramebuffer->hasAnyDirtyBit())
1156 {
1157 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
1158 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001159}
1160
1161void State::setDrawFramebufferBinding(Framebuffer *framebuffer)
1162{
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001163 if (mDrawFramebuffer == framebuffer)
1164 return;
1165
Shannon Woods53a94a82014-06-24 15:20:36 -04001166 mDrawFramebuffer = framebuffer;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001167 mDirtyBits.set(DIRTY_BIT_DRAW_FRAMEBUFFER_BINDING);
1168
1169 if (mDrawFramebuffer && mDrawFramebuffer->hasAnyDirtyBit())
1170 {
1171 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
1172 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001173}
1174
1175Framebuffer *State::getTargetFramebuffer(GLenum target) const
1176{
1177 switch (target)
1178 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001179 case GL_READ_FRAMEBUFFER_ANGLE:
1180 return mReadFramebuffer;
1181 case GL_DRAW_FRAMEBUFFER_ANGLE:
1182 case GL_FRAMEBUFFER:
1183 return mDrawFramebuffer;
1184 default:
1185 UNREACHABLE();
Yunchao Hef81ce4a2017-04-24 10:49:17 +08001186 return nullptr;
Shannon Woods53a94a82014-06-24 15:20:36 -04001187 }
1188}
1189
Jamie Madill51f40ec2016-06-15 14:06:00 -04001190Framebuffer *State::getReadFramebuffer() const
Shannon Woods53a94a82014-06-24 15:20:36 -04001191{
1192 return mReadFramebuffer;
1193}
1194
Shannon Woods53a94a82014-06-24 15:20:36 -04001195bool State::removeReadFramebufferBinding(GLuint framebuffer)
1196{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001197 if (mReadFramebuffer != nullptr && mReadFramebuffer->id() == framebuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001198 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001199 setReadFramebufferBinding(nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001200 return true;
1201 }
1202
1203 return false;
1204}
1205
1206bool State::removeDrawFramebufferBinding(GLuint framebuffer)
1207{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001208 if (mReadFramebuffer != nullptr && mDrawFramebuffer->id() == framebuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001209 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001210 setDrawFramebufferBinding(nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001211 return true;
1212 }
1213
1214 return false;
1215}
1216
Jamie Madill7267aa62018-04-17 15:28:21 -04001217void State::setVertexArrayBinding(const Context *context, VertexArray *vertexArray)
Shannon Woods53a94a82014-06-24 15:20:36 -04001218{
James Darpiniane8a93c62018-01-04 18:02:24 -08001219 if (mVertexArray == vertexArray)
1220 return;
1221 if (mVertexArray)
Jamie Madill7267aa62018-04-17 15:28:21 -04001222 mVertexArray->onBindingChanged(context, false);
Shannon Woods53a94a82014-06-24 15:20:36 -04001223 mVertexArray = vertexArray;
James Darpiniane8a93c62018-01-04 18:02:24 -08001224 if (vertexArray)
Jamie Madill7267aa62018-04-17 15:28:21 -04001225 vertexArray->onBindingChanged(context, true);
Jamie Madill0b9e9032015-08-17 11:51:52 +00001226 mDirtyBits.set(DIRTY_BIT_VERTEX_ARRAY_BINDING);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001227
1228 if (mVertexArray && mVertexArray->hasAnyDirtyBit())
1229 {
1230 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1231 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001232}
1233
1234GLuint State::getVertexArrayId() const
1235{
Yunchao He4f285442017-04-21 12:15:49 +08001236 ASSERT(mVertexArray != nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001237 return mVertexArray->id();
1238}
1239
Jamie Madill7267aa62018-04-17 15:28:21 -04001240bool State::removeVertexArrayBinding(const Context *context, GLuint vertexArray)
Shannon Woods53a94a82014-06-24 15:20:36 -04001241{
James Darpiniane8a93c62018-01-04 18:02:24 -08001242 if (mVertexArray && mVertexArray->id() == vertexArray)
Shannon Woods53a94a82014-06-24 15:20:36 -04001243 {
Jamie Madill7267aa62018-04-17 15:28:21 -04001244 mVertexArray->onBindingChanged(context, false);
Yunchao Hed7297bf2017-04-19 15:27:10 +08001245 mVertexArray = nullptr;
Jamie Madill0b9e9032015-08-17 11:51:52 +00001246 mDirtyBits.set(DIRTY_BIT_VERTEX_ARRAY_BINDING);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001247 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001248 return true;
1249 }
1250
1251 return false;
1252}
1253
Jamie Madill4928b7c2017-06-20 12:57:39 -04001254void State::bindVertexBuffer(const Context *context,
1255 GLuint bindingIndex,
Shao80957d92017-02-20 21:25:59 +08001256 Buffer *boundBuffer,
1257 GLintptr offset,
1258 GLsizei stride)
1259{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001260 getVertexArray()->bindVertexBuffer(context, bindingIndex, boundBuffer, offset, stride);
Shao80957d92017-02-20 21:25:59 +08001261 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1262}
1263
Shaodde78e82017-05-22 14:13:27 +08001264void State::setVertexAttribBinding(const Context *context, GLuint attribIndex, GLuint bindingIndex)
Shao80957d92017-02-20 21:25:59 +08001265{
Shaodde78e82017-05-22 14:13:27 +08001266 getVertexArray()->setVertexAttribBinding(context, attribIndex, bindingIndex);
Shao80957d92017-02-20 21:25:59 +08001267 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1268}
1269
1270void State::setVertexAttribFormat(GLuint attribIndex,
1271 GLint size,
1272 GLenum type,
1273 bool normalized,
1274 bool pureInteger,
1275 GLuint relativeOffset)
1276{
1277 getVertexArray()->setVertexAttribFormat(attribIndex, size, type, normalized, pureInteger,
1278 relativeOffset);
1279 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1280}
1281
1282void State::setVertexBindingDivisor(GLuint bindingIndex, GLuint divisor)
1283{
1284 getVertexArray()->setVertexBindingDivisor(bindingIndex, divisor);
1285 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1286}
1287
Jamie Madill6c1f6712017-02-14 19:08:04 -05001288void State::setProgram(const Context *context, Program *newProgram)
Shannon Woods53a94a82014-06-24 15:20:36 -04001289{
Geoff Lang7dd2e102014-11-10 15:19:26 -05001290 if (mProgram != newProgram)
Shannon Woods53a94a82014-06-24 15:20:36 -04001291 {
Geoff Lang7dd2e102014-11-10 15:19:26 -05001292 if (mProgram)
1293 {
Jamie Madill6c1f6712017-02-14 19:08:04 -05001294 mProgram->release(context);
Geoff Lang7dd2e102014-11-10 15:19:26 -05001295 }
1296
1297 mProgram = newProgram;
1298
1299 if (mProgram)
1300 {
1301 newProgram->addRef();
Jamie Madill81c2e252017-09-09 23:32:46 -04001302 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Geoff Lang7dd2e102014-11-10 15:19:26 -05001303 }
Jamie Madilla779b612017-07-24 11:46:05 -04001304 mDirtyBits.set(DIRTY_BIT_PROGRAM_EXECUTABLE);
1305 mDirtyBits.set(DIRTY_BIT_PROGRAM_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001306 }
1307}
1308
Jamie Madill4928b7c2017-06-20 12:57:39 -04001309void State::setTransformFeedbackBinding(const Context *context,
1310 TransformFeedback *transformFeedback)
Shannon Woods53a94a82014-06-24 15:20:36 -04001311{
James Darpiniane8a93c62018-01-04 18:02:24 -08001312 if (transformFeedback == mTransformFeedback.get())
1313 return;
1314 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -04001315 mTransformFeedback->onBindingChanged(context, false);
Jamie Madill4928b7c2017-06-20 12:57:39 -04001316 mTransformFeedback.set(context, transformFeedback);
James Darpiniane8a93c62018-01-04 18:02:24 -08001317 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -04001318 mTransformFeedback->onBindingChanged(context, true);
Geoff Langded79232017-11-28 15:21:11 -05001319 mDirtyBits.set(DIRTY_BIT_TRANSFORM_FEEDBACK_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001320}
1321
Gregoire Payen de La Garanderie52742022015-02-04 14:55:39 +00001322bool State::isTransformFeedbackActiveUnpaused() const
1323{
Jamie Madill4166f012018-05-31 14:53:30 -04001324 TransformFeedback *curTransformFeedback = mTransformFeedback.get();
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001325 return curTransformFeedback && curTransformFeedback->isActive() &&
1326 !curTransformFeedback->isPaused();
Gregoire Payen de La Garanderie52742022015-02-04 14:55:39 +00001327}
1328
Jamie Madill4928b7c2017-06-20 12:57:39 -04001329bool State::removeTransformFeedbackBinding(const Context *context, GLuint transformFeedback)
Shannon Woods53a94a82014-06-24 15:20:36 -04001330{
1331 if (mTransformFeedback.id() == transformFeedback)
1332 {
James Darpiniane8a93c62018-01-04 18:02:24 -08001333 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -04001334 mTransformFeedback->onBindingChanged(context, false);
Jamie Madill4928b7c2017-06-20 12:57:39 -04001335 mTransformFeedback.set(context, nullptr);
Corentin Walleza2257da2016-04-19 16:43:12 -04001336 return true;
Shannon Woods53a94a82014-06-24 15:20:36 -04001337 }
Corentin Walleza2257da2016-04-19 16:43:12 -04001338
1339 return false;
Shannon Woods53a94a82014-06-24 15:20:36 -04001340}
1341
Yunchao Hea336b902017-08-02 16:05:21 +08001342void State::setProgramPipelineBinding(const Context *context, ProgramPipeline *pipeline)
1343{
1344 mProgramPipeline.set(context, pipeline);
1345}
1346
1347void State::detachProgramPipeline(const Context *context, GLuint pipeline)
1348{
1349 mProgramPipeline.set(context, nullptr);
1350}
1351
Corentin Wallezad3ae902018-03-09 13:40:42 -05001352bool State::isQueryActive(QueryType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001353{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001354 const Query *query = mActiveQueries[type].get();
1355 if (query != nullptr)
Shannon Woods53a94a82014-06-24 15:20:36 -04001356 {
Corentin Wallezad3ae902018-03-09 13:40:42 -05001357 return true;
1358 }
1359
1360 QueryType alternativeType;
1361 if (GetAlternativeQueryType(type, &alternativeType))
1362 {
1363 query = mActiveQueries[alternativeType].get();
1364 return query != nullptr;
Ian Ewell3ffd78b2016-01-22 16:09:42 -05001365 }
1366
1367 return false;
1368}
1369
1370bool State::isQueryActive(Query *query) const
1371{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001372 for (auto &queryPointer : mActiveQueries)
Ian Ewell3ffd78b2016-01-22 16:09:42 -05001373 {
Corentin Wallezad3ae902018-03-09 13:40:42 -05001374 if (queryPointer.get() == query)
Shannon Woods53a94a82014-06-24 15:20:36 -04001375 {
1376 return true;
1377 }
1378 }
1379
1380 return false;
1381}
1382
Corentin Wallezad3ae902018-03-09 13:40:42 -05001383void State::setActiveQuery(const Context *context, QueryType type, Query *query)
Shannon Woods53a94a82014-06-24 15:20:36 -04001384{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001385 mActiveQueries[type].set(context, query);
Shannon Woods53a94a82014-06-24 15:20:36 -04001386}
1387
Corentin Wallezad3ae902018-03-09 13:40:42 -05001388GLuint State::getActiveQueryId(QueryType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001389{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001390 const Query *query = getActiveQuery(type);
Shannon Woods53a94a82014-06-24 15:20:36 -04001391 return (query ? query->id() : 0u);
1392}
1393
Corentin Wallezad3ae902018-03-09 13:40:42 -05001394Query *State::getActiveQuery(QueryType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001395{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001396 return mActiveQueries[type].get();
Shannon Woods53a94a82014-06-24 15:20:36 -04001397}
1398
Corentin Wallez336129f2017-10-17 15:55:40 -04001399void State::setBufferBinding(const Context *context, BufferBinding target, Buffer *buffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001400{
Corentin Wallez336129f2017-10-17 15:55:40 -04001401 switch (target)
1402 {
1403 case BufferBinding::PixelPack:
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_PACK_BUFFER_BINDING);
1406 break;
1407 case BufferBinding::PixelUnpack:
James Darpiniane8a93c62018-01-04 18:02:24 -08001408 UpdateBufferBinding(context, &mBoundBuffers[target], buffer, target);
Corentin Wallez336129f2017-10-17 15:55:40 -04001409 mDirtyBits.set(DIRTY_BIT_UNPACK_BUFFER_BINDING);
1410 break;
1411 case BufferBinding::DrawIndirect:
James Darpiniane8a93c62018-01-04 18:02:24 -08001412 UpdateBufferBinding(context, &mBoundBuffers[target], buffer, target);
Corentin Wallez336129f2017-10-17 15:55:40 -04001413 mDirtyBits.set(DIRTY_BIT_DRAW_INDIRECT_BUFFER_BINDING);
1414 break;
Qin Jiajiaa98a2812017-11-30 18:12:06 +08001415 case BufferBinding::DispatchIndirect:
James Darpiniane8a93c62018-01-04 18:02:24 -08001416 UpdateBufferBinding(context, &mBoundBuffers[target], buffer, target);
Qin Jiajiaa98a2812017-11-30 18:12:06 +08001417 mDirtyBits.set(DIRTY_BIT_DISPATCH_INDIRECT_BUFFER_BINDING);
1418 break;
Corentin Wallez336129f2017-10-17 15:55:40 -04001419 case BufferBinding::ElementArray:
1420 getVertexArray()->setElementArrayBuffer(context, buffer);
1421 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1422 break;
Xinghua Cao10a4d432017-11-28 14:46:26 +08001423 case BufferBinding::ShaderStorage:
James Darpiniane8a93c62018-01-04 18:02:24 -08001424 UpdateBufferBinding(context, &mBoundBuffers[target], buffer, target);
Xinghua Cao10a4d432017-11-28 14:46:26 +08001425 mDirtyBits.set(DIRTY_BIT_SHADER_STORAGE_BUFFER_BINDING);
1426 break;
Corentin Wallez336129f2017-10-17 15:55:40 -04001427 default:
James Darpiniane8a93c62018-01-04 18:02:24 -08001428 UpdateBufferBinding(context, &mBoundBuffers[target], buffer, target);
Corentin Wallez336129f2017-10-17 15:55:40 -04001429 break;
1430 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001431}
James Darpiniane8a93c62018-01-04 18:02:24 -08001432
Corentin Wallez336129f2017-10-17 15:55:40 -04001433void State::setIndexedBufferBinding(const Context *context,
1434 BufferBinding target,
1435 GLuint index,
1436 Buffer *buffer,
1437 GLintptr offset,
1438 GLsizeiptr size)
Jiajia Qin9d7d0b12016-11-29 16:30:31 +08001439{
Corentin Wallez336129f2017-10-17 15:55:40 -04001440 setBufferBinding(context, target, buffer);
Jiajia Qin9d7d0b12016-11-29 16:30:31 +08001441
Corentin Wallez336129f2017-10-17 15:55:40 -04001442 switch (target)
1443 {
1444 case BufferBinding::TransformFeedback:
1445 mTransformFeedback->bindIndexedBuffer(context, index, buffer, offset, size);
James Darpiniane8a93c62018-01-04 18:02:24 -08001446 setBufferBinding(context, target, buffer);
Corentin Wallez336129f2017-10-17 15:55:40 -04001447 break;
1448 case BufferBinding::Uniform:
James Darpiniane8a93c62018-01-04 18:02:24 -08001449 UpdateBufferBinding(context, &mUniformBuffers[index], buffer, target, offset, size);
Jamie Madillf4141212017-12-12 15:08:07 -05001450 mDirtyBits.set(DIRTY_BIT_UNIFORM_BUFFER_BINDINGS);
Corentin Wallez336129f2017-10-17 15:55:40 -04001451 break;
1452 case BufferBinding::AtomicCounter:
James Darpiniane8a93c62018-01-04 18:02:24 -08001453 UpdateBufferBinding(context, &mAtomicCounterBuffers[index], buffer, target, offset,
1454 size);
Corentin Wallez336129f2017-10-17 15:55:40 -04001455 break;
1456 case BufferBinding::ShaderStorage:
James Darpiniane8a93c62018-01-04 18:02:24 -08001457 UpdateBufferBinding(context, &mShaderStorageBuffers[index], buffer, target, offset,
1458 size);
Corentin Wallez336129f2017-10-17 15:55:40 -04001459 break;
1460 default:
1461 UNREACHABLE();
1462 break;
1463 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001464}
1465
Geoff Lang5d124a62015-09-15 13:03:27 -04001466const OffsetBindingPointer<Buffer> &State::getIndexedUniformBuffer(size_t index) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001467{
Shannon Woodsf3acaf92014-09-23 18:07:11 -04001468 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
Geoff Lang5d124a62015-09-15 13:03:27 -04001469 return mUniformBuffers[index];
Gregoire Payen de La Garanderie68694e92015-03-24 14:03:37 +00001470}
1471
Jiajia Qin6eafb042016-12-27 17:04:07 +08001472const OffsetBindingPointer<Buffer> &State::getIndexedAtomicCounterBuffer(size_t index) const
1473{
1474 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
1475 return mAtomicCounterBuffers[index];
1476}
1477
Jiajia Qinf546e7d2017-03-27 14:12:59 +08001478const OffsetBindingPointer<Buffer> &State::getIndexedShaderStorageBuffer(size_t index) const
1479{
1480 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
1481 return mShaderStorageBuffers[index];
1482}
1483
Corentin Wallez336129f2017-10-17 15:55:40 -04001484Buffer *State::getTargetBuffer(BufferBinding target) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001485{
1486 switch (target)
1487 {
Corentin Wallez336129f2017-10-17 15:55:40 -04001488 case BufferBinding::ElementArray:
1489 return getVertexArray()->getElementArrayBuffer().get();
Corentin Wallez336129f2017-10-17 15:55:40 -04001490 default:
1491 return mBoundBuffers[target].get();
Shannon Woods53a94a82014-06-24 15:20:36 -04001492 }
1493}
1494
James Darpinian4d9d4832018-03-13 12:43:28 -07001495void State::detachBuffer(const Context *context, const Buffer *buffer)
Yuly Novikov5807a532015-12-03 13:01:22 -05001496{
James Darpinian4d9d4832018-03-13 12:43:28 -07001497 if (!buffer->isBound())
1498 {
1499 return;
1500 }
1501 GLuint bufferName = buffer->id();
James Darpiniane8a93c62018-01-04 18:02:24 -08001502 for (auto target : angle::AllEnums<BufferBinding>())
Yuly Novikov5807a532015-12-03 13:01:22 -05001503 {
James Darpiniane8a93c62018-01-04 18:02:24 -08001504 if (mBoundBuffers[target].id() == bufferName)
Yuly Novikov5807a532015-12-03 13:01:22 -05001505 {
James Darpiniane8a93c62018-01-04 18:02:24 -08001506 UpdateBufferBinding(context, &mBoundBuffers[target], nullptr, target);
Yuly Novikov5807a532015-12-03 13:01:22 -05001507 }
1508 }
1509
1510 TransformFeedback *curTransformFeedback = getCurrentTransformFeedback();
1511 if (curTransformFeedback)
1512 {
Jamie Madill4928b7c2017-06-20 12:57:39 -04001513 curTransformFeedback->detachBuffer(context, bufferName);
Yuly Novikov5807a532015-12-03 13:01:22 -05001514 }
1515
Jamie Madill4928b7c2017-06-20 12:57:39 -04001516 getVertexArray()->detachBuffer(context, bufferName);
James Darpiniane8a93c62018-01-04 18:02:24 -08001517
1518 for (auto &buf : mUniformBuffers)
1519 {
1520 if (buf.id() == bufferName)
1521 {
1522 UpdateBufferBinding(context, &buf, nullptr, BufferBinding::Uniform);
1523 }
1524 }
1525
1526 for (auto &buf : mAtomicCounterBuffers)
1527 {
1528 if (buf.id() == bufferName)
1529 {
1530 UpdateBufferBinding(context, &buf, nullptr, BufferBinding::AtomicCounter);
1531 }
1532 }
1533
1534 for (auto &buf : mShaderStorageBuffers)
1535 {
1536 if (buf.id() == bufferName)
1537 {
1538 UpdateBufferBinding(context, &buf, nullptr, BufferBinding::ShaderStorage);
1539 }
1540 }
Yuly Novikov5807a532015-12-03 13:01:22 -05001541}
1542
Shannon Woods53a94a82014-06-24 15:20:36 -04001543void State::setEnableVertexAttribArray(unsigned int attribNum, bool enabled)
1544{
1545 getVertexArray()->enableAttribute(attribNum, enabled);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001546 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001547}
1548
1549void State::setVertexAttribf(GLuint index, const GLfloat values[4])
1550{
Shannon Woods23e05002014-09-22 19:07:27 -04001551 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001552 mVertexAttribCurrentValues[index].setFloatValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001553 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1554 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001555 mCurrentValuesTypeMask.setIndex(GL_FLOAT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001556}
1557
1558void State::setVertexAttribu(GLuint index, const GLuint values[4])
1559{
Shannon Woods23e05002014-09-22 19:07:27 -04001560 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001561 mVertexAttribCurrentValues[index].setUnsignedIntValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001562 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1563 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001564 mCurrentValuesTypeMask.setIndex(GL_UNSIGNED_INT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001565}
1566
1567void State::setVertexAttribi(GLuint index, const GLint values[4])
1568{
Shannon Woods23e05002014-09-22 19:07:27 -04001569 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001570 mVertexAttribCurrentValues[index].setIntValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001571 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1572 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001573 mCurrentValuesTypeMask.setIndex(GL_INT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001574}
1575
Shaodde78e82017-05-22 14:13:27 +08001576void State::setVertexAttribPointer(const Context *context,
1577 unsigned int attribNum,
1578 Buffer *boundBuffer,
1579 GLint size,
1580 GLenum type,
1581 bool normalized,
1582 bool pureInteger,
1583 GLsizei stride,
1584 const void *pointer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001585{
Shaodde78e82017-05-22 14:13:27 +08001586 getVertexArray()->setVertexAttribPointer(context, attribNum, boundBuffer, size, type,
1587 normalized, pureInteger, stride, pointer);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001588 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Jamie Madill0b9e9032015-08-17 11:51:52 +00001589}
1590
Shaodde78e82017-05-22 14:13:27 +08001591void State::setVertexAttribDivisor(const Context *context, GLuint index, GLuint divisor)
Jamie Madill0b9e9032015-08-17 11:51:52 +00001592{
Shaodde78e82017-05-22 14:13:27 +08001593 getVertexArray()->setVertexAttribDivisor(context, index, divisor);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001594 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001595}
1596
Jamie Madill6de51852017-04-12 09:53:01 -04001597const VertexAttribCurrentValueData &State::getVertexAttribCurrentValue(size_t attribNum) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001598{
Jamie Madill6de51852017-04-12 09:53:01 -04001599 ASSERT(attribNum < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001600 return mVertexAttribCurrentValues[attribNum];
1601}
1602
Jamie Madillcac94a92017-11-10 10:09:32 -05001603const std::vector<VertexAttribCurrentValueData> &State::getVertexAttribCurrentValues() const
1604{
1605 return mVertexAttribCurrentValues;
1606}
1607
Shannon Woods53a94a82014-06-24 15:20:36 -04001608const void *State::getVertexAttribPointer(unsigned int attribNum) const
1609{
1610 return getVertexArray()->getVertexAttribute(attribNum).pointer;
1611}
1612
1613void State::setPackAlignment(GLint alignment)
1614{
1615 mPack.alignment = alignment;
Jamie Madillc67323a2017-11-02 23:11:41 -04001616 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001617}
1618
1619GLint State::getPackAlignment() const
1620{
1621 return mPack.alignment;
1622}
1623
1624void State::setPackReverseRowOrder(bool reverseRowOrder)
1625{
1626 mPack.reverseRowOrder = reverseRowOrder;
Jamie Madillc67323a2017-11-02 23:11:41 -04001627 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001628}
1629
1630bool State::getPackReverseRowOrder() const
1631{
1632 return mPack.reverseRowOrder;
1633}
1634
Minmin Gongadff67b2015-10-14 10:34:45 -04001635void State::setPackRowLength(GLint rowLength)
1636{
1637 mPack.rowLength = rowLength;
Jamie Madillc67323a2017-11-02 23:11:41 -04001638 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001639}
1640
1641GLint State::getPackRowLength() const
1642{
1643 return mPack.rowLength;
1644}
1645
1646void State::setPackSkipRows(GLint skipRows)
1647{
1648 mPack.skipRows = skipRows;
Jamie Madillc67323a2017-11-02 23:11:41 -04001649 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001650}
1651
1652GLint State::getPackSkipRows() const
1653{
1654 return mPack.skipRows;
1655}
1656
1657void State::setPackSkipPixels(GLint skipPixels)
1658{
1659 mPack.skipPixels = skipPixels;
Jamie Madillc67323a2017-11-02 23:11:41 -04001660 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001661}
1662
1663GLint State::getPackSkipPixels() const
1664{
1665 return mPack.skipPixels;
1666}
1667
Shannon Woods53a94a82014-06-24 15:20:36 -04001668const PixelPackState &State::getPackState() const
1669{
1670 return mPack;
1671}
1672
Jamie Madill87de3622015-03-16 10:41:44 -04001673PixelPackState &State::getPackState()
1674{
1675 return mPack;
1676}
1677
Shannon Woods53a94a82014-06-24 15:20:36 -04001678void State::setUnpackAlignment(GLint alignment)
1679{
1680 mUnpack.alignment = alignment;
Jamie Madillc67323a2017-11-02 23:11:41 -04001681 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001682}
1683
1684GLint State::getUnpackAlignment() const
1685{
1686 return mUnpack.alignment;
1687}
1688
Minmin Gongb8aee3b2015-01-27 14:42:36 -08001689void State::setUnpackRowLength(GLint rowLength)
1690{
1691 mUnpack.rowLength = rowLength;
Jamie Madillc67323a2017-11-02 23:11:41 -04001692 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongb8aee3b2015-01-27 14:42:36 -08001693}
1694
1695GLint State::getUnpackRowLength() const
1696{
1697 return mUnpack.rowLength;
1698}
1699
Minmin Gongadff67b2015-10-14 10:34:45 -04001700void State::setUnpackImageHeight(GLint imageHeight)
1701{
1702 mUnpack.imageHeight = imageHeight;
Jamie Madillc67323a2017-11-02 23:11:41 -04001703 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001704}
1705
1706GLint State::getUnpackImageHeight() const
1707{
1708 return mUnpack.imageHeight;
1709}
1710
1711void State::setUnpackSkipImages(GLint skipImages)
1712{
1713 mUnpack.skipImages = skipImages;
Jamie Madillc67323a2017-11-02 23:11:41 -04001714 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001715}
1716
1717GLint State::getUnpackSkipImages() const
1718{
1719 return mUnpack.skipImages;
1720}
1721
1722void State::setUnpackSkipRows(GLint skipRows)
1723{
1724 mUnpack.skipRows = skipRows;
Jamie Madillc67323a2017-11-02 23:11:41 -04001725 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001726}
1727
1728GLint State::getUnpackSkipRows() const
1729{
1730 return mUnpack.skipRows;
1731}
1732
1733void State::setUnpackSkipPixels(GLint skipPixels)
1734{
1735 mUnpack.skipPixels = skipPixels;
Jamie Madillc67323a2017-11-02 23:11:41 -04001736 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001737}
1738
1739GLint State::getUnpackSkipPixels() const
1740{
1741 return mUnpack.skipPixels;
1742}
1743
Shannon Woods53a94a82014-06-24 15:20:36 -04001744const PixelUnpackState &State::getUnpackState() const
1745{
1746 return mUnpack;
1747}
1748
Jamie Madill67102f02015-03-16 10:41:42 -04001749PixelUnpackState &State::getUnpackState()
1750{
1751 return mUnpack;
1752}
1753
Geoff Lang70d0f492015-12-10 17:45:46 -05001754const Debug &State::getDebug() const
1755{
1756 return mDebug;
1757}
1758
1759Debug &State::getDebug()
1760{
1761 return mDebug;
1762}
1763
Sami Väisänena797e062016-05-12 15:23:40 +03001764void State::setCoverageModulation(GLenum components)
1765{
1766 mCoverageModulation = components;
1767 mDirtyBits.set(DIRTY_BIT_COVERAGE_MODULATION);
1768}
1769
1770GLenum State::getCoverageModulation() const
1771{
1772 return mCoverageModulation;
1773}
1774
Sami Väisänene45e53b2016-05-25 10:36:04 +03001775void State::loadPathRenderingMatrix(GLenum matrixMode, const GLfloat *matrix)
1776{
1777 if (matrixMode == GL_PATH_MODELVIEW_CHROMIUM)
1778 {
1779 memcpy(mPathMatrixMV, matrix, 16 * sizeof(GLfloat));
1780 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING_MATRIX_MV);
1781 }
1782 else if (matrixMode == GL_PATH_PROJECTION_CHROMIUM)
1783 {
1784 memcpy(mPathMatrixProj, matrix, 16 * sizeof(GLfloat));
1785 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING_MATRIX_PROJ);
1786 }
1787 else
1788 {
1789 UNREACHABLE();
1790 }
1791}
1792
1793const GLfloat *State::getPathRenderingMatrix(GLenum which) const
1794{
1795 if (which == GL_PATH_MODELVIEW_MATRIX_CHROMIUM)
1796 {
1797 return mPathMatrixMV;
1798 }
1799 else if (which == GL_PATH_PROJECTION_MATRIX_CHROMIUM)
1800 {
1801 return mPathMatrixProj;
1802 }
1803
1804 UNREACHABLE();
1805 return nullptr;
1806}
1807
1808void State::setPathStencilFunc(GLenum func, GLint ref, GLuint mask)
1809{
1810 mPathStencilFunc = func;
1811 mPathStencilRef = ref;
1812 mPathStencilMask = mask;
1813 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING_STENCIL_STATE);
1814}
1815
1816GLenum State::getPathStencilFunc() const
1817{
1818 return mPathStencilFunc;
1819}
1820
1821GLint State::getPathStencilRef() const
1822{
1823 return mPathStencilRef;
1824}
1825
1826GLuint State::getPathStencilMask() const
1827{
1828 return mPathStencilMask;
1829}
1830
Geoff Lang1d2c41d2016-10-19 16:14:46 -07001831void State::setFramebufferSRGB(bool sRGB)
1832{
1833 mFramebufferSRGB = sRGB;
1834 mDirtyBits.set(DIRTY_BIT_FRAMEBUFFER_SRGB);
1835}
1836
1837bool State::getFramebufferSRGB() const
1838{
1839 return mFramebufferSRGB;
1840}
1841
Shannon Woods53a94a82014-06-24 15:20:36 -04001842void State::getBooleanv(GLenum pname, GLboolean *params)
1843{
1844 switch (pname)
1845 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001846 case GL_SAMPLE_COVERAGE_INVERT:
1847 *params = mSampleCoverageInvert;
1848 break;
1849 case GL_DEPTH_WRITEMASK:
1850 *params = mDepthStencil.depthMask;
1851 break;
1852 case GL_COLOR_WRITEMASK:
1853 params[0] = mBlend.colorMaskRed;
1854 params[1] = mBlend.colorMaskGreen;
1855 params[2] = mBlend.colorMaskBlue;
1856 params[3] = mBlend.colorMaskAlpha;
1857 break;
1858 case GL_CULL_FACE:
1859 *params = mRasterizer.cullFace;
1860 break;
1861 case GL_POLYGON_OFFSET_FILL:
1862 *params = mRasterizer.polygonOffsetFill;
1863 break;
1864 case GL_SAMPLE_ALPHA_TO_COVERAGE:
1865 *params = mBlend.sampleAlphaToCoverage;
1866 break;
1867 case GL_SAMPLE_COVERAGE:
1868 *params = mSampleCoverage;
1869 break;
1870 case GL_SAMPLE_MASK:
1871 *params = mSampleMask;
1872 break;
1873 case GL_SCISSOR_TEST:
1874 *params = mScissorTest;
1875 break;
1876 case GL_STENCIL_TEST:
1877 *params = mDepthStencil.stencilTest;
1878 break;
1879 case GL_DEPTH_TEST:
1880 *params = mDepthStencil.depthTest;
1881 break;
1882 case GL_BLEND:
1883 *params = mBlend.blend;
1884 break;
1885 case GL_DITHER:
1886 *params = mBlend.dither;
1887 break;
1888 case GL_TRANSFORM_FEEDBACK_ACTIVE:
1889 *params = getCurrentTransformFeedback()->isActive() ? GL_TRUE : GL_FALSE;
1890 break;
1891 case GL_TRANSFORM_FEEDBACK_PAUSED:
1892 *params = getCurrentTransformFeedback()->isPaused() ? GL_TRUE : GL_FALSE;
1893 break;
1894 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
1895 *params = mPrimitiveRestart;
1896 break;
1897 case GL_RASTERIZER_DISCARD:
1898 *params = isRasterizerDiscardEnabled() ? GL_TRUE : GL_FALSE;
1899 break;
1900 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
1901 *params = mDebug.isOutputSynchronous() ? GL_TRUE : GL_FALSE;
1902 break;
1903 case GL_DEBUG_OUTPUT:
1904 *params = mDebug.isOutputEnabled() ? GL_TRUE : GL_FALSE;
1905 break;
1906 case GL_MULTISAMPLE_EXT:
1907 *params = mMultiSampling;
1908 break;
1909 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
1910 *params = mSampleAlphaToOne;
1911 break;
1912 case GL_BIND_GENERATES_RESOURCE_CHROMIUM:
1913 *params = isBindGeneratesResourceEnabled() ? GL_TRUE : GL_FALSE;
1914 break;
1915 case GL_CLIENT_ARRAYS_ANGLE:
1916 *params = areClientArraysEnabled() ? GL_TRUE : GL_FALSE;
1917 break;
1918 case GL_FRAMEBUFFER_SRGB_EXT:
1919 *params = getFramebufferSRGB() ? GL_TRUE : GL_FALSE;
1920 break;
1921 case GL_ROBUST_RESOURCE_INITIALIZATION_ANGLE:
1922 *params = mRobustResourceInit ? GL_TRUE : GL_FALSE;
1923 break;
1924 case GL_PROGRAM_CACHE_ENABLED_ANGLE:
1925 *params = mProgramBinaryCacheEnabled ? GL_TRUE : GL_FALSE;
1926 break;
Lingfeng Yangd0febe72018-05-17 22:36:52 -07001927 case GL_LIGHT_MODEL_TWO_SIDE:
1928 *params = IsLightModelTwoSided(&mGLES1State);
1929 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001930 default:
1931 UNREACHABLE();
1932 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04001933 }
1934}
1935
1936void State::getFloatv(GLenum pname, GLfloat *params)
1937{
1938 // Please note: DEPTH_CLEAR_VALUE is included in our internal getFloatv implementation
1939 // because it is stored as a float, despite the fact that the GL ES 2.0 spec names
1940 // GetIntegerv as its native query function. As it would require conversion in any
1941 // case, this should make no difference to the calling application.
1942 switch (pname)
1943 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001944 case GL_LINE_WIDTH:
1945 *params = mLineWidth;
1946 break;
1947 case GL_SAMPLE_COVERAGE_VALUE:
1948 *params = mSampleCoverageValue;
1949 break;
1950 case GL_DEPTH_CLEAR_VALUE:
1951 *params = mDepthClearValue;
1952 break;
1953 case GL_POLYGON_OFFSET_FACTOR:
1954 *params = mRasterizer.polygonOffsetFactor;
1955 break;
1956 case GL_POLYGON_OFFSET_UNITS:
1957 *params = mRasterizer.polygonOffsetUnits;
1958 break;
1959 case GL_DEPTH_RANGE:
1960 params[0] = mNearZ;
1961 params[1] = mFarZ;
1962 break;
1963 case GL_COLOR_CLEAR_VALUE:
1964 params[0] = mColorClearValue.red;
1965 params[1] = mColorClearValue.green;
1966 params[2] = mColorClearValue.blue;
1967 params[3] = mColorClearValue.alpha;
1968 break;
1969 case GL_BLEND_COLOR:
1970 params[0] = mBlendColor.red;
1971 params[1] = mBlendColor.green;
1972 params[2] = mBlendColor.blue;
1973 params[3] = mBlendColor.alpha;
1974 break;
1975 case GL_MULTISAMPLE_EXT:
1976 *params = static_cast<GLfloat>(mMultiSampling);
1977 break;
1978 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
1979 *params = static_cast<GLfloat>(mSampleAlphaToOne);
1980 break;
1981 case GL_COVERAGE_MODULATION_CHROMIUM:
1982 params[0] = static_cast<GLfloat>(mCoverageModulation);
1983 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -07001984 case GL_ALPHA_TEST_REF:
1985 *params = mGLES1State.mAlphaTestRef;
1986 break;
Lingfeng Yanga43994c2018-03-29 07:21:41 -07001987 case GL_CURRENT_COLOR:
1988 {
1989 const auto &color = mGLES1State.mCurrentColor;
1990 params[0] = color.red;
1991 params[1] = color.green;
1992 params[2] = color.blue;
1993 params[3] = color.alpha;
1994 break;
1995 }
Lingfeng Yang5a7e61b2018-03-29 16:50:32 -07001996 case GL_CURRENT_NORMAL:
1997 {
1998 const auto &normal = mGLES1State.mCurrentNormal;
1999 params[0] = normal[0];
2000 params[1] = normal[1];
2001 params[2] = normal[2];
2002 break;
2003 }
Lingfeng Yang038dd532018-03-29 17:31:52 -07002004 case GL_CURRENT_TEXTURE_COORDS:
2005 {
2006 const auto &texcoord = mGLES1State.mCurrentTextureCoords[mActiveSampler];
2007 params[0] = texcoord.s;
2008 params[1] = texcoord.t;
2009 params[2] = texcoord.r;
2010 params[3] = texcoord.q;
2011 break;
2012 }
Lingfeng Yang3a41af62018-04-09 07:28:56 -07002013 case GL_MODELVIEW_MATRIX:
2014 memcpy(params, mGLES1State.mModelviewMatrices.back().data(), 16 * sizeof(GLfloat));
2015 break;
2016 case GL_PROJECTION_MATRIX:
2017 memcpy(params, mGLES1State.mProjectionMatrices.back().data(), 16 * sizeof(GLfloat));
2018 break;
2019 case GL_TEXTURE_MATRIX:
2020 memcpy(params, mGLES1State.mTextureMatrices[mActiveSampler].back().data(),
2021 16 * sizeof(GLfloat));
2022 break;
Lingfeng Yangd0febe72018-05-17 22:36:52 -07002023 case GL_LIGHT_MODEL_AMBIENT:
2024 GetLightModelParameters(&mGLES1State, pname, params);
2025 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002026 default:
2027 UNREACHABLE();
2028 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002029 }
2030}
2031
Jamie Madille98b1b52018-03-08 09:47:23 -05002032Error State::getIntegerv(const Context *context, GLenum pname, GLint *params)
Shannon Woods53a94a82014-06-24 15:20:36 -04002033{
2034 if (pname >= GL_DRAW_BUFFER0_EXT && pname <= GL_DRAW_BUFFER15_EXT)
2035 {
2036 unsigned int colorAttachment = (pname - GL_DRAW_BUFFER0_EXT);
Shannon Woods2df6a602014-09-26 16:12:07 -04002037 ASSERT(colorAttachment < mMaxDrawBuffers);
Shannon Woods53a94a82014-06-24 15:20:36 -04002038 Framebuffer *framebuffer = mDrawFramebuffer;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002039 *params = framebuffer->getDrawBufferState(colorAttachment);
Jamie Madille98b1b52018-03-08 09:47:23 -05002040 return NoError();
Shannon Woods53a94a82014-06-24 15:20:36 -04002041 }
2042
2043 // Please note: DEPTH_CLEAR_VALUE is not included in our internal getIntegerv implementation
2044 // because it is stored as a float, despite the fact that the GL ES 2.0 spec names
2045 // GetIntegerv as its native query function. As it would require conversion in any
2046 // case, this should make no difference to the calling application. You may find it in
2047 // State::getFloatv.
2048 switch (pname)
2049 {
Corentin Wallez336129f2017-10-17 15:55:40 -04002050 case GL_ARRAY_BUFFER_BINDING:
2051 *params = mBoundBuffers[BufferBinding::Array].id();
2052 break;
2053 case GL_DRAW_INDIRECT_BUFFER_BINDING:
2054 *params = mBoundBuffers[BufferBinding::DrawIndirect].id();
2055 break;
2056 case GL_ELEMENT_ARRAY_BUFFER_BINDING:
2057 *params = getVertexArray()->getElementArrayBuffer().id();
2058 break;
Jamie Madill690c8eb2018-03-12 15:20:03 -04002059 case GL_DRAW_FRAMEBUFFER_BINDING:
2060 static_assert(GL_DRAW_FRAMEBUFFER_BINDING == GL_DRAW_FRAMEBUFFER_BINDING_ANGLE,
2061 "Enum mismatch");
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002062 *params = mDrawFramebuffer->id();
2063 break;
Jamie Madill690c8eb2018-03-12 15:20:03 -04002064 case GL_READ_FRAMEBUFFER_BINDING:
2065 static_assert(GL_READ_FRAMEBUFFER_BINDING == GL_READ_FRAMEBUFFER_BINDING_ANGLE,
2066 "Enum mismatch");
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002067 *params = mReadFramebuffer->id();
2068 break;
2069 case GL_RENDERBUFFER_BINDING:
2070 *params = mRenderbuffer.id();
2071 break;
2072 case GL_VERTEX_ARRAY_BINDING:
2073 *params = mVertexArray->id();
2074 break;
2075 case GL_CURRENT_PROGRAM:
2076 *params = mProgram ? mProgram->id() : 0;
2077 break;
2078 case GL_PACK_ALIGNMENT:
2079 *params = mPack.alignment;
2080 break;
2081 case GL_PACK_REVERSE_ROW_ORDER_ANGLE:
2082 *params = mPack.reverseRowOrder;
2083 break;
2084 case GL_PACK_ROW_LENGTH:
2085 *params = mPack.rowLength;
2086 break;
2087 case GL_PACK_SKIP_ROWS:
2088 *params = mPack.skipRows;
2089 break;
2090 case GL_PACK_SKIP_PIXELS:
2091 *params = mPack.skipPixels;
2092 break;
2093 case GL_UNPACK_ALIGNMENT:
2094 *params = mUnpack.alignment;
2095 break;
2096 case GL_UNPACK_ROW_LENGTH:
2097 *params = mUnpack.rowLength;
2098 break;
2099 case GL_UNPACK_IMAGE_HEIGHT:
2100 *params = mUnpack.imageHeight;
2101 break;
2102 case GL_UNPACK_SKIP_IMAGES:
2103 *params = mUnpack.skipImages;
2104 break;
2105 case GL_UNPACK_SKIP_ROWS:
2106 *params = mUnpack.skipRows;
2107 break;
2108 case GL_UNPACK_SKIP_PIXELS:
2109 *params = mUnpack.skipPixels;
2110 break;
2111 case GL_GENERATE_MIPMAP_HINT:
2112 *params = mGenerateMipmapHint;
2113 break;
2114 case GL_FRAGMENT_SHADER_DERIVATIVE_HINT_OES:
2115 *params = mFragmentShaderDerivativeHint;
2116 break;
2117 case GL_ACTIVE_TEXTURE:
2118 *params = (static_cast<GLint>(mActiveSampler) + GL_TEXTURE0);
2119 break;
2120 case GL_STENCIL_FUNC:
2121 *params = mDepthStencil.stencilFunc;
2122 break;
2123 case GL_STENCIL_REF:
2124 *params = mStencilRef;
2125 break;
2126 case GL_STENCIL_VALUE_MASK:
2127 *params = CastMaskValue(context, mDepthStencil.stencilMask);
2128 break;
2129 case GL_STENCIL_BACK_FUNC:
2130 *params = mDepthStencil.stencilBackFunc;
2131 break;
2132 case GL_STENCIL_BACK_REF:
2133 *params = mStencilBackRef;
2134 break;
2135 case GL_STENCIL_BACK_VALUE_MASK:
2136 *params = CastMaskValue(context, mDepthStencil.stencilBackMask);
2137 break;
2138 case GL_STENCIL_FAIL:
2139 *params = mDepthStencil.stencilFail;
2140 break;
2141 case GL_STENCIL_PASS_DEPTH_FAIL:
2142 *params = mDepthStencil.stencilPassDepthFail;
2143 break;
2144 case GL_STENCIL_PASS_DEPTH_PASS:
2145 *params = mDepthStencil.stencilPassDepthPass;
2146 break;
2147 case GL_STENCIL_BACK_FAIL:
2148 *params = mDepthStencil.stencilBackFail;
2149 break;
2150 case GL_STENCIL_BACK_PASS_DEPTH_FAIL:
2151 *params = mDepthStencil.stencilBackPassDepthFail;
2152 break;
2153 case GL_STENCIL_BACK_PASS_DEPTH_PASS:
2154 *params = mDepthStencil.stencilBackPassDepthPass;
2155 break;
2156 case GL_DEPTH_FUNC:
2157 *params = mDepthStencil.depthFunc;
2158 break;
2159 case GL_BLEND_SRC_RGB:
2160 *params = mBlend.sourceBlendRGB;
2161 break;
2162 case GL_BLEND_SRC_ALPHA:
2163 *params = mBlend.sourceBlendAlpha;
2164 break;
2165 case GL_BLEND_DST_RGB:
2166 *params = mBlend.destBlendRGB;
2167 break;
2168 case GL_BLEND_DST_ALPHA:
2169 *params = mBlend.destBlendAlpha;
2170 break;
2171 case GL_BLEND_EQUATION_RGB:
2172 *params = mBlend.blendEquationRGB;
2173 break;
2174 case GL_BLEND_EQUATION_ALPHA:
2175 *params = mBlend.blendEquationAlpha;
2176 break;
2177 case GL_STENCIL_WRITEMASK:
2178 *params = CastMaskValue(context, mDepthStencil.stencilWritemask);
2179 break;
2180 case GL_STENCIL_BACK_WRITEMASK:
2181 *params = CastMaskValue(context, mDepthStencil.stencilBackWritemask);
2182 break;
2183 case GL_STENCIL_CLEAR_VALUE:
2184 *params = mStencilClearValue;
2185 break;
2186 case GL_IMPLEMENTATION_COLOR_READ_TYPE:
Jamie Madill690c8eb2018-03-12 15:20:03 -04002187 ANGLE_TRY(mReadFramebuffer->getImplementationColorReadType(
2188 context, reinterpret_cast<GLenum *>(params)));
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002189 break;
2190 case GL_IMPLEMENTATION_COLOR_READ_FORMAT:
Jamie Madill690c8eb2018-03-12 15:20:03 -04002191 ANGLE_TRY(mReadFramebuffer->getImplementationColorReadFormat(
2192 context, reinterpret_cast<GLenum *>(params)));
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002193 break;
2194 case GL_SAMPLE_BUFFERS:
2195 case GL_SAMPLES:
Shannon Woods53a94a82014-06-24 15:20:36 -04002196 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002197 Framebuffer *framebuffer = mDrawFramebuffer;
Jamie Madill427064d2018-04-13 16:20:34 -04002198 if (framebuffer->isComplete(context))
Shannon Woods53a94a82014-06-24 15:20:36 -04002199 {
Jamie Madill427064d2018-04-13 16:20:34 -04002200 GLint samples = framebuffer->getSamples(context);
Shannon Woods53a94a82014-06-24 15:20:36 -04002201 switch (pname)
2202 {
Jamie Madilla0016b72017-07-14 14:30:46 -04002203 case GL_SAMPLE_BUFFERS:
Jamie Madille98b1b52018-03-08 09:47:23 -05002204 if (samples != 0)
Jamie Madilla0016b72017-07-14 14:30:46 -04002205 {
2206 *params = 1;
2207 }
2208 else
2209 {
2210 *params = 0;
2211 }
2212 break;
2213 case GL_SAMPLES:
Jamie Madille98b1b52018-03-08 09:47:23 -05002214 *params = samples;
Jamie Madilla0016b72017-07-14 14:30:46 -04002215 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002216 }
2217 }
2218 else
2219 {
2220 *params = 0;
2221 }
2222 }
2223 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002224 case GL_VIEWPORT:
2225 params[0] = mViewport.x;
2226 params[1] = mViewport.y;
2227 params[2] = mViewport.width;
2228 params[3] = mViewport.height;
2229 break;
2230 case GL_SCISSOR_BOX:
2231 params[0] = mScissor.x;
2232 params[1] = mScissor.y;
2233 params[2] = mScissor.width;
2234 params[3] = mScissor.height;
2235 break;
2236 case GL_CULL_FACE_MODE:
2237 *params = ToGLenum(mRasterizer.cullMode);
2238 break;
2239 case GL_FRONT_FACE:
2240 *params = mRasterizer.frontFace;
2241 break;
2242 case GL_RED_BITS:
2243 case GL_GREEN_BITS:
2244 case GL_BLUE_BITS:
2245 case GL_ALPHA_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002246 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002247 Framebuffer *framebuffer = getDrawFramebuffer();
2248 const FramebufferAttachment *colorbuffer = framebuffer->getFirstColorbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002249
2250 if (colorbuffer)
2251 {
2252 switch (pname)
2253 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002254 case GL_RED_BITS:
2255 *params = colorbuffer->getRedSize();
2256 break;
2257 case GL_GREEN_BITS:
2258 *params = colorbuffer->getGreenSize();
2259 break;
2260 case GL_BLUE_BITS:
2261 *params = colorbuffer->getBlueSize();
2262 break;
2263 case GL_ALPHA_BITS:
2264 *params = colorbuffer->getAlphaSize();
2265 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002266 }
2267 }
2268 else
2269 {
2270 *params = 0;
2271 }
2272 }
2273 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002274 case GL_DEPTH_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002275 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002276 const Framebuffer *framebuffer = getDrawFramebuffer();
2277 const FramebufferAttachment *depthbuffer = framebuffer->getDepthbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002278
2279 if (depthbuffer)
2280 {
2281 *params = depthbuffer->getDepthSize();
2282 }
2283 else
2284 {
2285 *params = 0;
2286 }
2287 }
2288 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002289 case GL_STENCIL_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002290 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002291 const Framebuffer *framebuffer = getDrawFramebuffer();
2292 const FramebufferAttachment *stencilbuffer = framebuffer->getStencilbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002293
2294 if (stencilbuffer)
2295 {
2296 *params = stencilbuffer->getStencilSize();
2297 }
2298 else
2299 {
2300 *params = 0;
2301 }
2302 }
2303 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002304 case GL_TEXTURE_BINDING_2D:
2305 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2306 *params =
2307 getSamplerTextureId(static_cast<unsigned int>(mActiveSampler), TextureType::_2D);
2308 break;
2309 case GL_TEXTURE_BINDING_RECTANGLE_ANGLE:
2310 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2311 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2312 TextureType::Rectangle);
2313 break;
2314 case GL_TEXTURE_BINDING_CUBE_MAP:
2315 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2316 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2317 TextureType::CubeMap);
2318 break;
2319 case GL_TEXTURE_BINDING_3D:
2320 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2321 *params =
2322 getSamplerTextureId(static_cast<unsigned int>(mActiveSampler), TextureType::_3D);
2323 break;
2324 case GL_TEXTURE_BINDING_2D_ARRAY:
2325 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2326 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2327 TextureType::_2DArray);
2328 break;
2329 case GL_TEXTURE_BINDING_2D_MULTISAMPLE:
2330 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2331 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2332 TextureType::_2DMultisample);
2333 break;
2334 case GL_TEXTURE_BINDING_EXTERNAL_OES:
2335 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2336 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2337 TextureType::External);
2338 break;
2339 case GL_UNIFORM_BUFFER_BINDING:
2340 *params = mBoundBuffers[BufferBinding::Uniform].id();
2341 break;
2342 case GL_TRANSFORM_FEEDBACK_BINDING:
2343 *params = mTransformFeedback.id();
2344 break;
2345 case GL_TRANSFORM_FEEDBACK_BUFFER_BINDING:
2346 *params = mBoundBuffers[BufferBinding::TransformFeedback].id();
2347 break;
2348 case GL_COPY_READ_BUFFER_BINDING:
2349 *params = mBoundBuffers[BufferBinding::CopyRead].id();
2350 break;
2351 case GL_COPY_WRITE_BUFFER_BINDING:
2352 *params = mBoundBuffers[BufferBinding::CopyWrite].id();
2353 break;
2354 case GL_PIXEL_PACK_BUFFER_BINDING:
2355 *params = mBoundBuffers[BufferBinding::PixelPack].id();
2356 break;
2357 case GL_PIXEL_UNPACK_BUFFER_BINDING:
2358 *params = mBoundBuffers[BufferBinding::PixelUnpack].id();
2359 break;
2360 case GL_READ_BUFFER:
2361 *params = mReadFramebuffer->getReadBufferState();
2362 break;
2363 case GL_SAMPLER_BINDING:
2364 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2365 *params = getSamplerId(static_cast<GLuint>(mActiveSampler));
2366 break;
2367 case GL_DEBUG_LOGGED_MESSAGES:
2368 *params = static_cast<GLint>(mDebug.getMessageCount());
2369 break;
2370 case GL_DEBUG_NEXT_LOGGED_MESSAGE_LENGTH:
2371 *params = static_cast<GLint>(mDebug.getNextMessageLength());
2372 break;
2373 case GL_DEBUG_GROUP_STACK_DEPTH:
2374 *params = static_cast<GLint>(mDebug.getGroupStackDepth());
2375 break;
2376 case GL_MULTISAMPLE_EXT:
2377 *params = static_cast<GLint>(mMultiSampling);
2378 break;
2379 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
2380 *params = static_cast<GLint>(mSampleAlphaToOne);
2381 break;
2382 case GL_COVERAGE_MODULATION_CHROMIUM:
2383 *params = static_cast<GLint>(mCoverageModulation);
2384 break;
2385 case GL_ATOMIC_COUNTER_BUFFER_BINDING:
2386 *params = mBoundBuffers[BufferBinding::AtomicCounter].id();
2387 break;
2388 case GL_SHADER_STORAGE_BUFFER_BINDING:
2389 *params = mBoundBuffers[BufferBinding::ShaderStorage].id();
2390 break;
2391 case GL_DISPATCH_INDIRECT_BUFFER_BINDING:
2392 *params = mBoundBuffers[BufferBinding::DispatchIndirect].id();
2393 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -07002394 case GL_ALPHA_TEST_FUNC:
2395 *params = ToGLenum(mGLES1State.mAlphaTestFunc);
2396 break;
Lingfeng Yang96310cd2018-03-28 11:56:28 -07002397 case GL_CLIENT_ACTIVE_TEXTURE:
2398 *params = mGLES1State.mClientActiveTexture + GL_TEXTURE0;
2399 break;
Lingfeng Yangd2488ab2018-04-04 09:25:48 -07002400 case GL_MATRIX_MODE:
2401 *params = ToGLenum(mGLES1State.mMatrixMode);
2402 break;
Lingfeng Yanga0cfa872018-05-30 21:12:17 -07002403 case GL_SHADE_MODEL:
2404 *params = ToGLenum(mGLES1State.mShadeModel);
2405 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002406 default:
2407 UNREACHABLE();
2408 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002409 }
Jamie Madille98b1b52018-03-08 09:47:23 -05002410
2411 return NoError();
Shannon Woods53a94a82014-06-24 15:20:36 -04002412}
2413
Lingfeng Yangabb09f12018-04-16 10:43:53 -07002414void State::getPointerv(const Context *context, GLenum pname, void **params) const
Geoff Lang70d0f492015-12-10 17:45:46 -05002415{
2416 switch (pname)
2417 {
2418 case GL_DEBUG_CALLBACK_FUNCTION:
2419 *params = reinterpret_cast<void *>(mDebug.getCallback());
2420 break;
2421 case GL_DEBUG_CALLBACK_USER_PARAM:
2422 *params = const_cast<void *>(mDebug.getUserParam());
2423 break;
Lingfeng Yangabb09f12018-04-16 10:43:53 -07002424 case GL_VERTEX_ARRAY_POINTER:
2425 case GL_NORMAL_ARRAY_POINTER:
2426 case GL_COLOR_ARRAY_POINTER:
2427 case GL_TEXTURE_COORD_ARRAY_POINTER:
2428 case GL_POINT_SIZE_ARRAY_POINTER_OES:
2429 QueryVertexAttribPointerv(getVertexArray()->getVertexAttribute(
2430 context->vertexArrayIndex(ParamToVertexArrayType(pname))),
2431 GL_VERTEX_ATTRIB_ARRAY_POINTER, params);
2432 return;
Geoff Lang70d0f492015-12-10 17:45:46 -05002433 default:
2434 UNREACHABLE();
2435 break;
2436 }
2437}
2438
Martin Radev66fb8202016-07-28 11:45:20 +03002439void State::getIntegeri_v(GLenum target, GLuint index, GLint *data)
Shannon Woods53a94a82014-06-24 15:20:36 -04002440{
2441 switch (target)
2442 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002443 case GL_TRANSFORM_FEEDBACK_BUFFER_BINDING:
2444 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2445 *data = mTransformFeedback->getIndexedBuffer(index).id();
2446 break;
2447 case GL_UNIFORM_BUFFER_BINDING:
2448 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2449 *data = mUniformBuffers[index].id();
2450 break;
2451 case GL_ATOMIC_COUNTER_BUFFER_BINDING:
2452 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2453 *data = mAtomicCounterBuffers[index].id();
2454 break;
2455 case GL_SHADER_STORAGE_BUFFER_BINDING:
2456 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2457 *data = mShaderStorageBuffers[index].id();
2458 break;
2459 case GL_VERTEX_BINDING_BUFFER:
2460 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2461 *data = mVertexArray->getVertexBinding(index).getBuffer().id();
2462 break;
2463 case GL_VERTEX_BINDING_DIVISOR:
2464 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2465 *data = mVertexArray->getVertexBinding(index).getDivisor();
2466 break;
2467 case GL_VERTEX_BINDING_OFFSET:
2468 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2469 *data = static_cast<GLuint>(mVertexArray->getVertexBinding(index).getOffset());
2470 break;
2471 case GL_VERTEX_BINDING_STRIDE:
2472 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2473 *data = mVertexArray->getVertexBinding(index).getStride();
2474 break;
2475 case GL_SAMPLE_MASK_VALUE:
2476 ASSERT(static_cast<size_t>(index) < mSampleMaskValues.size());
2477 *data = mSampleMaskValues[index];
2478 break;
2479 case GL_IMAGE_BINDING_NAME:
2480 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2481 *data = mImageUnits[index].texture.id();
2482 break;
2483 case GL_IMAGE_BINDING_LEVEL:
2484 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2485 *data = mImageUnits[index].level;
2486 break;
2487 case GL_IMAGE_BINDING_LAYER:
2488 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2489 *data = mImageUnits[index].layer;
2490 break;
2491 case GL_IMAGE_BINDING_ACCESS:
2492 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2493 *data = mImageUnits[index].access;
2494 break;
2495 case GL_IMAGE_BINDING_FORMAT:
2496 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2497 *data = mImageUnits[index].format;
2498 break;
2499 default:
2500 UNREACHABLE();
2501 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002502 }
Shannon Woods53a94a82014-06-24 15:20:36 -04002503}
2504
Martin Radev66fb8202016-07-28 11:45:20 +03002505void State::getInteger64i_v(GLenum target, GLuint index, GLint64 *data)
Shannon Woods53a94a82014-06-24 15:20:36 -04002506{
2507 switch (target)
2508 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002509 case GL_TRANSFORM_FEEDBACK_BUFFER_START:
2510 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2511 *data = mTransformFeedback->getIndexedBuffer(index).getOffset();
2512 break;
2513 case GL_TRANSFORM_FEEDBACK_BUFFER_SIZE:
2514 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2515 *data = mTransformFeedback->getIndexedBuffer(index).getSize();
2516 break;
2517 case GL_UNIFORM_BUFFER_START:
2518 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2519 *data = mUniformBuffers[index].getOffset();
2520 break;
2521 case GL_UNIFORM_BUFFER_SIZE:
2522 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2523 *data = mUniformBuffers[index].getSize();
2524 break;
2525 case GL_ATOMIC_COUNTER_BUFFER_START:
2526 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2527 *data = mAtomicCounterBuffers[index].getOffset();
2528 break;
2529 case GL_ATOMIC_COUNTER_BUFFER_SIZE:
2530 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2531 *data = mAtomicCounterBuffers[index].getSize();
2532 break;
2533 case GL_SHADER_STORAGE_BUFFER_START:
2534 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2535 *data = mShaderStorageBuffers[index].getOffset();
2536 break;
2537 case GL_SHADER_STORAGE_BUFFER_SIZE:
2538 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2539 *data = mShaderStorageBuffers[index].getSize();
2540 break;
2541 default:
2542 UNREACHABLE();
2543 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002544 }
Martin Radev66fb8202016-07-28 11:45:20 +03002545}
Shannon Woods53a94a82014-06-24 15:20:36 -04002546
Martin Radev66fb8202016-07-28 11:45:20 +03002547void State::getBooleani_v(GLenum target, GLuint index, GLboolean *data)
2548{
Xinghua Cao9c8e1a32017-12-06 17:59:58 +08002549 switch (target)
2550 {
2551 case GL_IMAGE_BINDING_LAYERED:
2552 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2553 *data = mImageUnits[index].layered;
2554 break;
2555 default:
2556 UNREACHABLE();
2557 break;
2558 }
Shannon Woods53a94a82014-06-24 15:20:36 -04002559}
2560
Corentin Wallez336129f2017-10-17 15:55:40 -04002561bool State::hasMappedBuffer(BufferBinding target) const
Jamie Madilld9ba4f72014-08-04 10:47:59 -04002562{
Corentin Wallez336129f2017-10-17 15:55:40 -04002563 if (target == BufferBinding::Array)
Jamie Madilld9ba4f72014-08-04 10:47:59 -04002564 {
Jiawei-Shao2597fb62016-12-09 16:38:02 +08002565 const VertexArray *vao = getVertexArray();
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002566 const auto &vertexAttribs = vao->getVertexAttributes();
Jiawei-Shao2597fb62016-12-09 16:38:02 +08002567 const auto &vertexBindings = vao->getVertexBindings();
Jamie Madilld078c682018-01-02 11:50:24 -05002568 for (size_t attribIndex : vao->getEnabledAttributesMask())
Jamie Madilld9ba4f72014-08-04 10:47:59 -04002569 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002570 const VertexAttribute &vertexAttrib = vertexAttribs[attribIndex];
Martin Radevdd5f27e2017-06-07 10:17:09 +03002571 auto *boundBuffer = vertexBindings[vertexAttrib.bindingIndex].getBuffer().get();
Jamie Madilld9ba4f72014-08-04 10:47:59 -04002572 if (vertexAttrib.enabled && boundBuffer && boundBuffer->isMapped())
2573 {
2574 return true;
2575 }
2576 }
2577
2578 return false;
2579 }
2580 else
2581 {
2582 Buffer *buffer = getTargetBuffer(target);
2583 return (buffer && buffer->isMapped());
2584 }
2585}
2586
Jamie Madillbc918e72018-03-08 09:47:21 -05002587Error State::syncDirtyObjects(const Context *context)
Jamie Madillc9d442d2016-01-20 11:17:24 -05002588{
2589 if (!mDirtyObjects.any())
Jamie Madillbc918e72018-03-08 09:47:21 -05002590 return NoError();
Jamie Madillc9d442d2016-01-20 11:17:24 -05002591
Jamie Madillbc918e72018-03-08 09:47:21 -05002592 return syncDirtyObjects(context, mDirtyObjects);
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002593}
2594
Jamie Madillbc918e72018-03-08 09:47:21 -05002595Error State::syncDirtyObjects(const Context *context, const DirtyObjects &bitset)
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002596{
Jiajia Qin5ae6ee42018-03-06 17:39:42 +08002597 const DirtyObjects &dirtyObjects = mDirtyObjects & bitset;
2598 for (auto dirtyObject : dirtyObjects)
Jamie Madillc9d442d2016-01-20 11:17:24 -05002599 {
2600 switch (dirtyObject)
2601 {
2602 case DIRTY_OBJECT_READ_FRAMEBUFFER:
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002603 ASSERT(mReadFramebuffer);
Jamie Madill19fa1c62018-03-08 09:47:21 -05002604 ANGLE_TRY(mReadFramebuffer->syncState(context));
Jamie Madillc9d442d2016-01-20 11:17:24 -05002605 break;
2606 case DIRTY_OBJECT_DRAW_FRAMEBUFFER:
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002607 ASSERT(mDrawFramebuffer);
Jamie Madill19fa1c62018-03-08 09:47:21 -05002608 ANGLE_TRY(mDrawFramebuffer->syncState(context));
Jamie Madillc9d442d2016-01-20 11:17:24 -05002609 break;
2610 case DIRTY_OBJECT_VERTEX_ARRAY:
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002611 ASSERT(mVertexArray);
Frank Henigman0af5b862018-03-27 20:19:33 -04002612 ANGLE_TRY(mVertexArray->syncState(context));
Jamie Madillc9d442d2016-01-20 11:17:24 -05002613 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002614 case DIRTY_OBJECT_PROGRAM_TEXTURES:
Luc Ferron4bba74f2018-04-19 14:40:45 -04002615 ANGLE_TRY(syncProgramTextures(context));
Jamie Madill81c2e252017-09-09 23:32:46 -04002616 break;
2617
Jamie Madillc9d442d2016-01-20 11:17:24 -05002618 default:
2619 UNREACHABLE();
2620 break;
2621 }
2622 }
2623
Jiajia Qin5ae6ee42018-03-06 17:39:42 +08002624 mDirtyObjects &= ~dirtyObjects;
Jamie Madillbc918e72018-03-08 09:47:21 -05002625 return NoError();
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002626}
2627
Luc Ferron4bba74f2018-04-19 14:40:45 -04002628Error State::syncProgramTextures(const Context *context)
Jamie Madill81c2e252017-09-09 23:32:46 -04002629{
Jamie Madill81c2e252017-09-09 23:32:46 -04002630 // TODO(jmadill): Fine-grained updates.
2631 if (!mProgram)
2632 {
Luc Ferron4bba74f2018-04-19 14:40:45 -04002633 return NoError();
Jamie Madill81c2e252017-09-09 23:32:46 -04002634 }
2635
2636 ASSERT(mDirtyObjects[DIRTY_OBJECT_PROGRAM_TEXTURES]);
2637 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
2638
Jamie Madill0f80ed82017-09-19 00:24:56 -04002639 ActiveTextureMask newActiveTextures;
2640
Geoff Lange51ba632017-11-21 11:45:25 -05002641 // Initialize to the 'Initialized' state and set to 'MayNeedInit' if any texture is not
2642 // initialized.
2643 mCachedTexturesInitState = InitState::Initialized;
2644
Jamie Madill81c2e252017-09-09 23:32:46 -04002645 for (const SamplerBinding &samplerBinding : mProgram->getSamplerBindings())
2646 {
2647 if (samplerBinding.unreferenced)
2648 continue;
2649
Corentin Wallezf0e89be2017-11-08 14:00:32 -08002650 TextureType textureType = samplerBinding.textureType;
Jamie Madill81c2e252017-09-09 23:32:46 -04002651 for (GLuint textureUnitIndex : samplerBinding.boundTextureUnits)
2652 {
2653 Texture *texture = getSamplerTexture(textureUnitIndex, textureType);
Jamie Madill06ef36b2017-09-09 23:32:46 -04002654 Sampler *sampler = getSampler(textureUnitIndex);
Jamie Madill0f80ed82017-09-19 00:24:56 -04002655 ASSERT(static_cast<size_t>(textureUnitIndex) < mCompleteTextureCache.size());
2656 ASSERT(static_cast<size_t>(textureUnitIndex) < newActiveTextures.size());
Jamie Madill81c2e252017-09-09 23:32:46 -04002657
Jamie Madill42975642017-10-12 12:31:51 -04002658 ASSERT(texture);
Jamie Madill81c2e252017-09-09 23:32:46 -04002659
Jamie Madill42975642017-10-12 12:31:51 -04002660 // Mark the texture binding bit as dirty if the texture completeness changes.
2661 // TODO(jmadill): Use specific dirty bit for completeness change.
2662 if (texture->isSamplerComplete(context, sampler) &&
2663 !mDrawFramebuffer->hasTextureAttachment(texture))
2664 {
Luc Ferron4bba74f2018-04-19 14:40:45 -04002665 ANGLE_TRY(texture->syncState(context));
Jamie Madill42975642017-10-12 12:31:51 -04002666 mCompleteTextureCache[textureUnitIndex] = texture;
Jamie Madill81c2e252017-09-09 23:32:46 -04002667 }
Jamie Madill42975642017-10-12 12:31:51 -04002668 else
2669 {
2670 mCompleteTextureCache[textureUnitIndex] = nullptr;
2671 }
2672
2673 // Bind the texture unconditionally, to recieve completeness change notifications.
Jamie Madill888081d2018-02-27 00:24:46 -05002674 mCompleteTextureBindings[textureUnitIndex].bind(texture->getSubject());
Jamie Madilla59fc192017-11-02 12:57:58 -04002675 mActiveTexturesMask.set(textureUnitIndex);
Jamie Madill42975642017-10-12 12:31:51 -04002676 newActiveTextures.set(textureUnitIndex);
Jamie Madill81c2e252017-09-09 23:32:46 -04002677
Jamie Madill06ef36b2017-09-09 23:32:46 -04002678 if (sampler != nullptr)
2679 {
2680 sampler->syncState(context);
2681 }
Geoff Lange51ba632017-11-21 11:45:25 -05002682
2683 if (texture->initState() == InitState::MayNeedInit)
2684 {
2685 mCachedTexturesInitState = InitState::MayNeedInit;
2686 }
Jamie Madill81c2e252017-09-09 23:32:46 -04002687 }
2688 }
Jamie Madill0f80ed82017-09-19 00:24:56 -04002689
2690 // Unset now missing textures.
Jamie Madilla59fc192017-11-02 12:57:58 -04002691 ActiveTextureMask negativeMask = mActiveTexturesMask & ~newActiveTextures;
Jamie Madill0f80ed82017-09-19 00:24:56 -04002692 if (negativeMask.any())
2693 {
2694 for (auto textureIndex : negativeMask)
2695 {
2696 mCompleteTextureBindings[textureIndex].reset();
2697 mCompleteTextureCache[textureIndex] = nullptr;
Jamie Madilla59fc192017-11-02 12:57:58 -04002698 mActiveTexturesMask.reset(textureIndex);
Jamie Madill0f80ed82017-09-19 00:24:56 -04002699 }
2700 }
Luc Ferron4bba74f2018-04-19 14:40:45 -04002701
2702 return NoError();
Jamie Madill81c2e252017-09-09 23:32:46 -04002703}
2704
Jamie Madillbc918e72018-03-08 09:47:21 -05002705Error State::syncDirtyObject(const Context *context, GLenum target)
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002706{
2707 DirtyObjects localSet;
2708
2709 switch (target)
2710 {
2711 case GL_READ_FRAMEBUFFER:
2712 localSet.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2713 break;
2714 case GL_DRAW_FRAMEBUFFER:
2715 localSet.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2716 break;
2717 case GL_FRAMEBUFFER:
2718 localSet.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2719 localSet.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2720 break;
2721 case GL_VERTEX_ARRAY:
2722 localSet.set(DIRTY_OBJECT_VERTEX_ARRAY);
2723 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002724 case GL_TEXTURE:
2725 case GL_SAMPLER:
2726 case GL_PROGRAM:
2727 localSet.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
2728 break;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002729 }
2730
Jamie Madillbc918e72018-03-08 09:47:21 -05002731 return syncDirtyObjects(context, localSet);
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002732}
2733
2734void State::setObjectDirty(GLenum target)
2735{
2736 switch (target)
2737 {
2738 case GL_READ_FRAMEBUFFER:
2739 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2740 break;
2741 case GL_DRAW_FRAMEBUFFER:
2742 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2743 break;
2744 case GL_FRAMEBUFFER:
2745 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2746 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2747 break;
2748 case GL_VERTEX_ARRAY:
2749 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
2750 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002751 case GL_TEXTURE:
2752 case GL_SAMPLER:
Jamie Madill81c2e252017-09-09 23:32:46 -04002753 case GL_PROGRAM:
2754 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
2755 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
2756 break;
Jamie Madilla779b612017-07-24 11:46:05 -04002757 }
2758}
2759
Jamie Madill888081d2018-02-27 00:24:46 -05002760void State::setFramebufferDirty(const Framebuffer *framebuffer) const
2761{
2762 if (framebuffer == mReadFramebuffer)
2763 {
2764 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2765 }
2766 if (framebuffer == mDrawFramebuffer)
2767 {
2768 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2769 }
2770}
2771
Jamie Madill09463932018-04-04 05:26:59 -04002772void State::setVertexArrayDirty(const VertexArray *vertexArray) const
2773{
2774 if (vertexArray == mVertexArray)
2775 {
2776 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
2777 }
2778}
2779
Jamie Madilla779b612017-07-24 11:46:05 -04002780void State::onProgramExecutableChange(Program *program)
2781{
2782 // OpenGL Spec:
2783 // "If LinkProgram or ProgramBinary successfully re-links a program object
2784 // that was already in use as a result of a previous call to UseProgram, then the
2785 // generated executable code will be installed as part of the current rendering state."
2786 if (program->isLinked() && mProgram == program)
2787 {
2788 mDirtyBits.set(DIRTY_BIT_PROGRAM_EXECUTABLE);
Jamie Madill81c2e252017-09-09 23:32:46 -04002789 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002790 }
Shannon Woods53a94a82014-06-24 15:20:36 -04002791}
Jamie Madillc9d442d2016-01-20 11:17:24 -05002792
Xinghua Cao65ec0b22017-03-28 16:10:52 +08002793void State::setImageUnit(const Context *context,
2794 GLuint unit,
2795 Texture *texture,
2796 GLint level,
2797 GLboolean layered,
2798 GLint layer,
2799 GLenum access,
2800 GLenum format)
2801{
2802 mImageUnits[unit].texture.set(context, texture);
2803 mImageUnits[unit].level = level;
2804 mImageUnits[unit].layered = layered;
2805 mImageUnits[unit].layer = layer;
2806 mImageUnits[unit].access = access;
2807 mImageUnits[unit].format = format;
2808}
2809
2810const ImageUnit &State::getImageUnit(GLuint unit) const
2811{
2812 return mImageUnits[unit];
2813}
2814
Jamie Madill81c2e252017-09-09 23:32:46 -04002815// Handle a dirty texture event.
Jamie Madilld4442552018-02-27 22:03:47 -05002816void State::onSubjectStateChange(const Context *context,
2817 angle::SubjectIndex index,
2818 angle::SubjectMessage message)
Jamie Madill81c2e252017-09-09 23:32:46 -04002819{
2820 // Conservatively assume all textures are dirty.
2821 // TODO(jmadill): More fine-grained update.
2822 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Geoff Lange51ba632017-11-21 11:45:25 -05002823
Jamie Madilld4442552018-02-27 22:03:47 -05002824 if (!mCompleteTextureCache[index] ||
2825 mCompleteTextureCache[index]->initState() == InitState::MayNeedInit)
Geoff Lange51ba632017-11-21 11:45:25 -05002826 {
2827 mCachedTexturesInitState = InitState::MayNeedInit;
2828 }
Jamie Madill81c2e252017-09-09 23:32:46 -04002829}
2830
Jamie Madill05b35b22017-10-03 09:01:44 -04002831Error State::clearUnclearedActiveTextures(const Context *context)
2832{
Jamie Madilla59fc192017-11-02 12:57:58 -04002833 ASSERT(mRobustResourceInit);
Jamie Madill05b35b22017-10-03 09:01:44 -04002834
Geoff Lange51ba632017-11-21 11:45:25 -05002835 if (mCachedTexturesInitState == InitState::Initialized)
2836 {
2837 return NoError();
2838 }
2839
Geoff Langd4fff502017-09-22 11:28:28 -04002840 ASSERT(!mDirtyObjects.any());
2841
Jamie Madilla59fc192017-11-02 12:57:58 -04002842 for (auto textureIndex : mActiveTexturesMask)
Jamie Madill05b35b22017-10-03 09:01:44 -04002843 {
Jamie Madilla59fc192017-11-02 12:57:58 -04002844 Texture *texture = mCompleteTextureCache[textureIndex];
Jamie Madill05b35b22017-10-03 09:01:44 -04002845 if (texture)
2846 {
2847 ANGLE_TRY(texture->ensureInitialized(context));
2848 }
2849 }
Jamie Madilla59fc192017-11-02 12:57:58 -04002850
Geoff Lange51ba632017-11-21 11:45:25 -05002851 mCachedTexturesInitState = InitState::Initialized;
2852
Jamie Madill05b35b22017-10-03 09:01:44 -04002853 return NoError();
2854}
2855
Jamie Madillc67323a2017-11-02 23:11:41 -04002856AttributesMask State::getAndResetDirtyCurrentValues() const
2857{
2858 AttributesMask retVal = mDirtyCurrentValues;
2859 mDirtyCurrentValues.reset();
2860 return retVal;
2861}
2862
James Darpiniane8a93c62018-01-04 18:02:24 -08002863bool State::isCurrentTransformFeedback(const TransformFeedback *tf) const
2864{
2865 return tf == mTransformFeedback.get();
2866}
2867bool State::isCurrentVertexArray(const VertexArray *va) const
2868{
2869 return va == mVertexArray;
2870}
2871
Jamie Madillc9d442d2016-01-20 11:17:24 -05002872} // namespace gl