blob: eea13f98502abc9d54042f05b3dd19113cd57b54 [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"
Geoff Lang4751aab2017-10-30 15:14:52 -040026#include "libANGLE/renderer/ContextImpl.h"
Shannon Woods53a94a82014-06-24 15:20:36 -040027
Olli Etuahobbf1c102016-06-28 13:31:33 +030028namespace
29{
30
31GLenum ActiveQueryType(const GLenum type)
32{
33 return (type == GL_ANY_SAMPLES_PASSED_CONSERVATIVE) ? GL_ANY_SAMPLES_PASSED : type;
34}
35
36} // anonymous namepace
37
Shannon Woods53a94a82014-06-24 15:20:36 -040038namespace gl
39{
Geoff Lang76b10c92014-09-05 16:28:14 -040040
James Darpiniane8a93c62018-01-04 18:02:24 -080041void UpdateBufferBinding(const Context *context,
42 BindingPointer<Buffer> *binding,
43 Buffer *buffer,
44 BufferBinding target)
45{
46 if (binding->get())
47 (*binding)->onBindingChanged(false, target);
48 binding->set(context, buffer);
49 if (binding->get())
50 (*binding)->onBindingChanged(true, target);
51}
52
53void UpdateBufferBinding(const Context *context,
54 OffsetBindingPointer<Buffer> *binding,
55 Buffer *buffer,
56 BufferBinding target,
57 GLintptr offset,
58 GLsizeiptr size)
59{
60 if (binding->get())
61 (*binding)->onBindingChanged(false, target);
62 binding->set(context, buffer, offset, size);
63 if (binding->get())
64 (*binding)->onBindingChanged(true, target);
65}
66
Shannon Woods53a94a82014-06-24 15:20:36 -040067State::State()
Jamie Madille79b1e12015-11-04 16:36:37 -050068 : mMaxDrawBuffers(0),
69 mMaxCombinedTextureImageUnits(0),
70 mDepthClearValue(0),
71 mStencilClearValue(0),
72 mScissorTest(false),
73 mSampleCoverage(false),
74 mSampleCoverageValue(0),
75 mSampleCoverageInvert(false),
Jiawei Shaodb342272017-09-27 10:21:45 +080076 mSampleMask(false),
77 mMaxSampleMaskWords(0),
Jamie Madille79b1e12015-11-04 16:36:37 -050078 mStencilRef(0),
79 mStencilBackRef(0),
80 mLineWidth(0),
81 mGenerateMipmapHint(GL_NONE),
82 mFragmentShaderDerivativeHint(GL_NONE),
Geoff Langf41a7152016-09-19 15:11:17 -040083 mBindGeneratesResource(true),
Geoff Langfeb8c682017-02-13 16:07:35 -050084 mClientArraysEnabled(true),
Jamie Madille79b1e12015-11-04 16:36:37 -050085 mNearZ(0),
86 mFarZ(0),
87 mReadFramebuffer(nullptr),
88 mDrawFramebuffer(nullptr),
89 mProgram(nullptr),
90 mVertexArray(nullptr),
91 mActiveSampler(0),
Sami Väisänen74c23472016-05-09 17:30:30 +030092 mPrimitiveRestart(false),
93 mMultiSampling(false),
Geoff Lang1d2c41d2016-10-19 16:14:46 -070094 mSampleAlphaToOne(false),
Jamie Madille08a1d32017-03-07 17:24:06 -050095 mFramebufferSRGB(true),
Jamie Madillc43be722017-07-13 16:22:14 -040096 mRobustResourceInit(false),
97 mProgramBinaryCacheEnabled(false)
Shannon Woods53a94a82014-06-24 15:20:36 -040098{
Geoff Lang76b10c92014-09-05 16:28:14 -040099}
100
Lingfeng Yang13b708f2018-03-21 12:14:10 -0700101State::~State()
102{
103}
Geoff Lang76b10c92014-09-05 16:28:14 -0400104
Jamie Madill4928b7c2017-06-20 12:57:39 -0400105void State::initialize(const Context *context,
Geoff Langf41a7152016-09-19 15:11:17 -0400106 bool debug,
Geoff Langfeb8c682017-02-13 16:07:35 -0500107 bool bindGeneratesResource,
Jamie Madille08a1d32017-03-07 17:24:06 -0500108 bool clientArraysEnabled,
Jamie Madillc43be722017-07-13 16:22:14 -0400109 bool robustResourceInit,
110 bool programBinaryCacheEnabled)
Geoff Lang76b10c92014-09-05 16:28:14 -0400111{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700112 const Caps &caps = context->getCaps();
113 const Extensions &extensions = context->getExtensions();
Geoff Lang4751aab2017-10-30 15:14:52 -0400114 const Extensions &nativeExtensions = context->getImplementation()->getNativeExtensions();
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700115 const Version &clientVersion = context->getClientVersion();
Jamie Madill4928b7c2017-06-20 12:57:39 -0400116
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700117 mMaxDrawBuffers = caps.maxDrawBuffers;
Shannon Woods2df6a602014-09-26 16:12:07 -0400118 mMaxCombinedTextureImageUnits = caps.maxCombinedTextureImageUnits;
Shannon Woods53a94a82014-06-24 15:20:36 -0400119
Jamie Madillf75ab352015-03-16 10:46:52 -0400120 setColorClearValue(0.0f, 0.0f, 0.0f, 0.0f);
Shannon Woods53a94a82014-06-24 15:20:36 -0400121
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700122 mDepthClearValue = 1.0f;
Shannon Woods53a94a82014-06-24 15:20:36 -0400123 mStencilClearValue = 0;
124
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700125 mScissorTest = false;
126 mScissor.x = 0;
127 mScissor.y = 0;
128 mScissor.width = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400129 mScissor.height = 0;
130
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700131 mBlendColor.red = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400132 mBlendColor.green = 0;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700133 mBlendColor.blue = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400134 mBlendColor.alpha = 0;
135
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700136 mStencilRef = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400137 mStencilBackRef = 0;
138
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700139 mSampleCoverage = false;
140 mSampleCoverageValue = 1.0f;
Shannon Woods53a94a82014-06-24 15:20:36 -0400141 mSampleCoverageInvert = false;
Jiawei Shaodb342272017-09-27 10:21:45 +0800142
143 mMaxSampleMaskWords = caps.maxSampleMaskWords;
144 mSampleMask = false;
145 mSampleMaskValues.fill(~GLbitfield(0));
146
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700147 mGenerateMipmapHint = GL_DONT_CARE;
Shannon Woods53a94a82014-06-24 15:20:36 -0400148 mFragmentShaderDerivativeHint = GL_DONT_CARE;
149
Geoff Langf41a7152016-09-19 15:11:17 -0400150 mBindGeneratesResource = bindGeneratesResource;
Geoff Langfeb8c682017-02-13 16:07:35 -0500151 mClientArraysEnabled = clientArraysEnabled;
Geoff Langf41a7152016-09-19 15:11:17 -0400152
Shannon Woods53a94a82014-06-24 15:20:36 -0400153 mLineWidth = 1.0f;
154
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700155 mViewport.x = 0;
156 mViewport.y = 0;
157 mViewport.width = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400158 mViewport.height = 0;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700159 mNearZ = 0.0f;
160 mFarZ = 1.0f;
Shannon Woods53a94a82014-06-24 15:20:36 -0400161
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700162 mBlend.colorMaskRed = true;
Shannon Woods53a94a82014-06-24 15:20:36 -0400163 mBlend.colorMaskGreen = true;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700164 mBlend.colorMaskBlue = true;
Shannon Woods53a94a82014-06-24 15:20:36 -0400165 mBlend.colorMaskAlpha = true;
166
Geoff Lang76b10c92014-09-05 16:28:14 -0400167 mActiveSampler = 0;
168
Shannon Woods23e05002014-09-22 19:07:27 -0400169 mVertexAttribCurrentValues.resize(caps.maxVertexAttributes);
Shannon Woods53a94a82014-06-24 15:20:36 -0400170
Brandon Jonesc405ae72017-12-06 14:15:03 -0800171 // Set all indexes in state attributes type mask to float (default)
172 for (int i = 0; i < MAX_VERTEX_ATTRIBS; i++)
173 {
174 mCurrentValuesTypeMask.setIndex(GL_FLOAT, i);
175 }
176
Geoff Lang4dc3af02016-11-18 14:09:27 -0500177 mUniformBuffers.resize(caps.maxUniformBufferBindings);
Shannon Woodsf3acaf92014-09-23 18:07:11 -0400178
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800179 mSamplerTextures[TextureType::_2D].resize(caps.maxCombinedTextureImageUnits);
180 mSamplerTextures[TextureType::CubeMap].resize(caps.maxCombinedTextureImageUnits);
Geoff Langeb66a6e2016-10-31 13:06:12 -0400181 if (clientVersion >= Version(3, 0))
Shannon Woods53a94a82014-06-24 15:20:36 -0400182 {
Geoff Lang76b10c92014-09-05 16:28:14 -0400183 // TODO: These could also be enabled via extension
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800184 mSamplerTextures[TextureType::_2DArray].resize(caps.maxCombinedTextureImageUnits);
185 mSamplerTextures[TextureType::_3D].resize(caps.maxCombinedTextureImageUnits);
Shannon Woods53a94a82014-06-24 15:20:36 -0400186 }
Geoff Lang3b573612016-10-31 14:08:10 -0400187 if (clientVersion >= Version(3, 1))
188 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800189 mSamplerTextures[TextureType::_2DMultisample].resize(caps.maxCombinedTextureImageUnits);
Jiajia Qin6eafb042016-12-27 17:04:07 +0800190
191 mAtomicCounterBuffers.resize(caps.maxAtomicCounterBufferBindings);
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800192 mShaderStorageBuffers.resize(caps.maxShaderStorageBufferBindings);
Xinghua Cao65ec0b22017-03-28 16:10:52 +0800193 mImageUnits.resize(caps.maxImageUnits);
Geoff Lang3b573612016-10-31 14:08:10 -0400194 }
Geoff Lang4751aab2017-10-30 15:14:52 -0400195 if (nativeExtensions.textureRectangle)
Corentin Wallez13c0dd42017-07-04 18:27:01 -0400196 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800197 mSamplerTextures[TextureType::Rectangle].resize(caps.maxCombinedTextureImageUnits);
Corentin Wallez13c0dd42017-07-04 18:27:01 -0400198 }
Geoff Lang4751aab2017-10-30 15:14:52 -0400199 if (nativeExtensions.eglImageExternal || nativeExtensions.eglStreamConsumerExternal)
Ian Ewellbda75592016-04-18 17:25:54 -0400200 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800201 mSamplerTextures[TextureType::External].resize(caps.maxCombinedTextureImageUnits);
Ian Ewellbda75592016-04-18 17:25:54 -0400202 }
Jamie Madill81c2e252017-09-09 23:32:46 -0400203 mCompleteTextureCache.resize(caps.maxCombinedTextureImageUnits, nullptr);
204 mCompleteTextureBindings.reserve(caps.maxCombinedTextureImageUnits);
Geoff Lange51ba632017-11-21 11:45:25 -0500205 mCachedTexturesInitState = InitState::MayNeedInit;
Jamie Madill81c2e252017-09-09 23:32:46 -0400206 for (uint32_t textureIndex = 0; textureIndex < caps.maxCombinedTextureImageUnits;
207 ++textureIndex)
208 {
Jamie Madilld4442552018-02-27 22:03:47 -0500209 mCompleteTextureBindings.emplace_back(this, textureIndex);
Jamie Madill81c2e252017-09-09 23:32:46 -0400210 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400211
Geoff Lang76b10c92014-09-05 16:28:14 -0400212 mSamplers.resize(caps.maxCombinedTextureImageUnits);
Shannon Woods53a94a82014-06-24 15:20:36 -0400213
Jamie Madill4928b7c2017-06-20 12:57:39 -0400214 mActiveQueries[GL_ANY_SAMPLES_PASSED].set(context, nullptr);
215 mActiveQueries[GL_ANY_SAMPLES_PASSED_CONSERVATIVE].set(context, nullptr);
216 mActiveQueries[GL_TRANSFORM_FEEDBACK_PRIMITIVES_WRITTEN].set(context, nullptr);
217 mActiveQueries[GL_TIME_ELAPSED_EXT].set(context, nullptr);
218 mActiveQueries[GL_COMMANDS_COMPLETED_CHROMIUM].set(context, nullptr);
Jiawei Shaod2fa07e2018-03-15 09:20:25 +0800219 mActiveQueries[GL_PRIMITIVES_GENERATED_EXT].set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400220
Ian Ewell3ffd78b2016-01-22 16:09:42 -0500221 mProgram = nullptr;
Shannon Woods53a94a82014-06-24 15:20:36 -0400222
Ian Ewell3ffd78b2016-01-22 16:09:42 -0500223 mReadFramebuffer = nullptr;
224 mDrawFramebuffer = nullptr;
Jamie Madillb4b53c52015-02-03 15:22:48 -0500225
226 mPrimitiveRestart = false;
Geoff Lang70d0f492015-12-10 17:45:46 -0500227
228 mDebug.setOutputEnabled(debug);
229 mDebug.setMaxLoggedMessages(extensions.maxDebugLoggedMessages);
Sami Väisänen74c23472016-05-09 17:30:30 +0300230
Geoff Lang488130e2017-09-27 13:53:11 -0400231 mMultiSampling = true;
232 mSampleAlphaToOne = false;
Sami Väisänena797e062016-05-12 15:23:40 +0300233
234 mCoverageModulation = GL_NONE;
Sami Väisänene45e53b2016-05-25 10:36:04 +0300235
236 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixProj);
237 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixMV);
238 mPathStencilFunc = GL_ALWAYS;
239 mPathStencilRef = 0;
240 mPathStencilMask = std::numeric_limits<GLuint>::max();
Jamie Madille08a1d32017-03-07 17:24:06 -0500241
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700242 mRobustResourceInit = robustResourceInit;
Jamie Madillc43be722017-07-13 16:22:14 -0400243 mProgramBinaryCacheEnabled = programBinaryCacheEnabled;
Lingfeng Yangdbb9c532018-02-25 19:58:24 -0800244
245 // GLES1 emulation: Initialize state for GLES1 if version
246 // applies
247 if (clientVersion < Version(2, 0))
248 {
Lingfeng Yange547aac2018-04-05 09:39:20 -0700249 mGLES1State.initialize(context, this);
Lingfeng Yangdbb9c532018-02-25 19:58:24 -0800250 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400251}
252
Jamie Madill6c1f6712017-02-14 19:08:04 -0500253void State::reset(const Context *context)
Shannon Woods53a94a82014-06-24 15:20:36 -0400254{
Jamie Madill8693bdb2017-09-02 15:32:14 -0400255 for (auto &bindingVec : mSamplerTextures)
Shannon Woods53a94a82014-06-24 15:20:36 -0400256 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800257 for (size_t textureIdx = 0; textureIdx < bindingVec.size(); textureIdx++)
Shannon Woods53a94a82014-06-24 15:20:36 -0400258 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800259 bindingVec[textureIdx].set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400260 }
261 }
Geoff Lang76b10c92014-09-05 16:28:14 -0400262 for (size_t samplerIdx = 0; samplerIdx < mSamplers.size(); samplerIdx++)
263 {
Jamie Madill4928b7c2017-06-20 12:57:39 -0400264 mSamplers[samplerIdx].set(context, nullptr);
Geoff Lang76b10c92014-09-05 16:28:14 -0400265 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400266
Xinghua Cao65ec0b22017-03-28 16:10:52 +0800267 for (auto &imageUnit : mImageUnits)
268 {
269 imageUnit.texture.set(context, nullptr);
270 imageUnit.level = 0;
271 imageUnit.layered = false;
272 imageUnit.layer = 0;
273 imageUnit.access = GL_READ_ONLY;
274 imageUnit.format = GL_R32UI;
275 }
276
Jamie Madill4928b7c2017-06-20 12:57:39 -0400277 mRenderbuffer.set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400278
Corentin Wallez336129f2017-10-17 15:55:40 -0400279 for (auto type : angle::AllEnums<BufferBinding>())
280 {
James Darpiniane8a93c62018-01-04 18:02:24 -0800281 UpdateBufferBinding(context, &mBoundBuffers[type], nullptr, type);
Corentin Wallez336129f2017-10-17 15:55:40 -0400282 }
283
Geoff Lang7dd2e102014-11-10 15:19:26 -0500284 if (mProgram)
285 {
Jamie Madill6c1f6712017-02-14 19:08:04 -0500286 mProgram->release(context);
Geoff Lang7dd2e102014-11-10 15:19:26 -0500287 }
Yunchao Hed7297bf2017-04-19 15:27:10 +0800288 mProgram = nullptr;
Geoff Lang7dd2e102014-11-10 15:19:26 -0500289
Yunchao Hea336b902017-08-02 16:05:21 +0800290 mProgramPipeline.set(context, nullptr);
291
James Darpiniane8a93c62018-01-04 18:02:24 -0800292 if (mTransformFeedback.get())
293 mTransformFeedback->onBindingChanged(false);
Jamie Madill4928b7c2017-06-20 12:57:39 -0400294 mTransformFeedback.set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400295
296 for (State::ActiveQueryMap::iterator i = mActiveQueries.begin(); i != mActiveQueries.end(); i++)
297 {
Jamie Madill4928b7c2017-06-20 12:57:39 -0400298 i->second.set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400299 }
300
Corentin Wallez336129f2017-10-17 15:55:40 -0400301 for (auto &buf : mUniformBuffers)
Shannon Woods53a94a82014-06-24 15:20:36 -0400302 {
James Darpiniane8a93c62018-01-04 18:02:24 -0800303 UpdateBufferBinding(context, &buf, nullptr, BufferBinding::Uniform);
Shannon Woods53a94a82014-06-24 15:20:36 -0400304 }
305
Jiajia Qin6eafb042016-12-27 17:04:07 +0800306 for (auto &buf : mAtomicCounterBuffers)
307 {
James Darpiniane8a93c62018-01-04 18:02:24 -0800308 UpdateBufferBinding(context, &buf, nullptr, BufferBinding::AtomicCounter);
Jiajia Qin6eafb042016-12-27 17:04:07 +0800309 }
310
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800311 for (auto &buf : mShaderStorageBuffers)
312 {
James Darpiniane8a93c62018-01-04 18:02:24 -0800313 UpdateBufferBinding(context, &buf, nullptr, BufferBinding::ShaderStorage);
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800314 }
315
Sami Väisänene45e53b2016-05-25 10:36:04 +0300316 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixProj);
317 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixMV);
318 mPathStencilFunc = GL_ALWAYS;
319 mPathStencilRef = 0;
320 mPathStencilMask = std::numeric_limits<GLuint>::max();
321
Jamie Madill1b94d432015-08-07 13:23:23 -0400322 // TODO(jmadill): Is this necessary?
323 setAllDirtyBits();
Shannon Woods53a94a82014-06-24 15:20:36 -0400324}
325
326const RasterizerState &State::getRasterizerState() const
327{
328 return mRasterizer;
329}
330
331const BlendState &State::getBlendState() const
332{
333 return mBlend;
334}
335
336const DepthStencilState &State::getDepthStencilState() const
337{
338 return mDepthStencil;
339}
340
Jamie Madillf75ab352015-03-16 10:46:52 -0400341void State::setColorClearValue(float red, float green, float blue, float alpha)
Shannon Woods53a94a82014-06-24 15:20:36 -0400342{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700343 mColorClearValue.red = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400344 mColorClearValue.green = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700345 mColorClearValue.blue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400346 mColorClearValue.alpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400347 mDirtyBits.set(DIRTY_BIT_CLEAR_COLOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400348}
349
Jamie Madillf75ab352015-03-16 10:46:52 -0400350void State::setDepthClearValue(float depth)
Shannon Woods53a94a82014-06-24 15:20:36 -0400351{
352 mDepthClearValue = depth;
Jamie Madill1b94d432015-08-07 13:23:23 -0400353 mDirtyBits.set(DIRTY_BIT_CLEAR_DEPTH);
Shannon Woods53a94a82014-06-24 15:20:36 -0400354}
355
Jamie Madillf75ab352015-03-16 10:46:52 -0400356void State::setStencilClearValue(int stencil)
Shannon Woods53a94a82014-06-24 15:20:36 -0400357{
358 mStencilClearValue = stencil;
Jamie Madill1b94d432015-08-07 13:23:23 -0400359 mDirtyBits.set(DIRTY_BIT_CLEAR_STENCIL);
Shannon Woods53a94a82014-06-24 15:20:36 -0400360}
361
Shannon Woods53a94a82014-06-24 15:20:36 -0400362void State::setColorMask(bool red, bool green, bool blue, bool alpha)
363{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700364 mBlend.colorMaskRed = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400365 mBlend.colorMaskGreen = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700366 mBlend.colorMaskBlue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400367 mBlend.colorMaskAlpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400368 mDirtyBits.set(DIRTY_BIT_COLOR_MASK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400369}
370
371void State::setDepthMask(bool mask)
372{
373 mDepthStencil.depthMask = mask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400374 mDirtyBits.set(DIRTY_BIT_DEPTH_MASK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400375}
376
377bool State::isRasterizerDiscardEnabled() const
378{
379 return mRasterizer.rasterizerDiscard;
380}
381
382void State::setRasterizerDiscard(bool enabled)
383{
384 mRasterizer.rasterizerDiscard = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400385 mDirtyBits.set(DIRTY_BIT_RASTERIZER_DISCARD_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400386}
387
388bool State::isCullFaceEnabled() const
389{
390 return mRasterizer.cullFace;
391}
392
393void State::setCullFace(bool enabled)
394{
395 mRasterizer.cullFace = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400396 mDirtyBits.set(DIRTY_BIT_CULL_FACE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400397}
398
Corentin Wallez2e568cf2017-09-18 17:05:22 -0400399void State::setCullMode(CullFaceMode mode)
Shannon Woods53a94a82014-06-24 15:20:36 -0400400{
401 mRasterizer.cullMode = mode;
Jamie Madill1b94d432015-08-07 13:23:23 -0400402 mDirtyBits.set(DIRTY_BIT_CULL_FACE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400403}
404
405void State::setFrontFace(GLenum front)
406{
407 mRasterizer.frontFace = front;
Jamie Madill1b94d432015-08-07 13:23:23 -0400408 mDirtyBits.set(DIRTY_BIT_FRONT_FACE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400409}
410
411bool State::isDepthTestEnabled() const
412{
413 return mDepthStencil.depthTest;
414}
415
416void State::setDepthTest(bool enabled)
417{
418 mDepthStencil.depthTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400419 mDirtyBits.set(DIRTY_BIT_DEPTH_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400420}
421
422void State::setDepthFunc(GLenum depthFunc)
423{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700424 mDepthStencil.depthFunc = depthFunc;
425 mDirtyBits.set(DIRTY_BIT_DEPTH_FUNC);
Shannon Woods53a94a82014-06-24 15:20:36 -0400426}
427
428void State::setDepthRange(float zNear, float zFar)
429{
430 mNearZ = zNear;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700431 mFarZ = zFar;
Jamie Madill1b94d432015-08-07 13:23:23 -0400432 mDirtyBits.set(DIRTY_BIT_DEPTH_RANGE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400433}
434
Geoff Langd42f5b82015-04-16 14:03:29 -0400435float State::getNearPlane() const
Shannon Woods53a94a82014-06-24 15:20:36 -0400436{
Geoff Langd42f5b82015-04-16 14:03:29 -0400437 return mNearZ;
438}
439
440float State::getFarPlane() const
441{
442 return mFarZ;
Shannon Woods53a94a82014-06-24 15:20:36 -0400443}
444
445bool State::isBlendEnabled() const
446{
447 return mBlend.blend;
448}
449
450void State::setBlend(bool enabled)
451{
452 mBlend.blend = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400453 mDirtyBits.set(DIRTY_BIT_BLEND_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400454}
455
456void State::setBlendFactors(GLenum sourceRGB, GLenum destRGB, GLenum sourceAlpha, GLenum destAlpha)
457{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700458 mBlend.sourceBlendRGB = sourceRGB;
459 mBlend.destBlendRGB = destRGB;
Shannon Woods53a94a82014-06-24 15:20:36 -0400460 mBlend.sourceBlendAlpha = sourceAlpha;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700461 mBlend.destBlendAlpha = destAlpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400462 mDirtyBits.set(DIRTY_BIT_BLEND_FUNCS);
Shannon Woods53a94a82014-06-24 15:20:36 -0400463}
464
465void State::setBlendColor(float red, float green, float blue, float alpha)
466{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700467 mBlendColor.red = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400468 mBlendColor.green = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700469 mBlendColor.blue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400470 mBlendColor.alpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400471 mDirtyBits.set(DIRTY_BIT_BLEND_COLOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400472}
473
474void State::setBlendEquation(GLenum rgbEquation, GLenum alphaEquation)
475{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700476 mBlend.blendEquationRGB = rgbEquation;
Shannon Woods53a94a82014-06-24 15:20:36 -0400477 mBlend.blendEquationAlpha = alphaEquation;
Jamie Madill1b94d432015-08-07 13:23:23 -0400478 mDirtyBits.set(DIRTY_BIT_BLEND_EQUATIONS);
Shannon Woods53a94a82014-06-24 15:20:36 -0400479}
480
481const ColorF &State::getBlendColor() const
482{
483 return mBlendColor;
484}
485
486bool State::isStencilTestEnabled() const
487{
488 return mDepthStencil.stencilTest;
489}
490
491void State::setStencilTest(bool enabled)
492{
493 mDepthStencil.stencilTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400494 mDirtyBits.set(DIRTY_BIT_STENCIL_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400495}
496
497void State::setStencilParams(GLenum stencilFunc, GLint stencilRef, GLuint stencilMask)
498{
499 mDepthStencil.stencilFunc = stencilFunc;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700500 mStencilRef = (stencilRef > 0) ? stencilRef : 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400501 mDepthStencil.stencilMask = stencilMask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400502 mDirtyBits.set(DIRTY_BIT_STENCIL_FUNCS_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400503}
504
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700505void State::setStencilBackParams(GLenum stencilBackFunc,
506 GLint stencilBackRef,
507 GLuint stencilBackMask)
Shannon Woods53a94a82014-06-24 15:20:36 -0400508{
509 mDepthStencil.stencilBackFunc = stencilBackFunc;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700510 mStencilBackRef = (stencilBackRef > 0) ? stencilBackRef : 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400511 mDepthStencil.stencilBackMask = stencilBackMask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400512 mDirtyBits.set(DIRTY_BIT_STENCIL_FUNCS_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400513}
514
515void State::setStencilWritemask(GLuint stencilWritemask)
516{
517 mDepthStencil.stencilWritemask = stencilWritemask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400518 mDirtyBits.set(DIRTY_BIT_STENCIL_WRITEMASK_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400519}
520
521void State::setStencilBackWritemask(GLuint stencilBackWritemask)
522{
523 mDepthStencil.stencilBackWritemask = stencilBackWritemask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400524 mDirtyBits.set(DIRTY_BIT_STENCIL_WRITEMASK_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400525}
526
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700527void State::setStencilOperations(GLenum stencilFail,
528 GLenum stencilPassDepthFail,
529 GLenum stencilPassDepthPass)
Shannon Woods53a94a82014-06-24 15:20:36 -0400530{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700531 mDepthStencil.stencilFail = stencilFail;
Shannon Woods53a94a82014-06-24 15:20:36 -0400532 mDepthStencil.stencilPassDepthFail = stencilPassDepthFail;
533 mDepthStencil.stencilPassDepthPass = stencilPassDepthPass;
Jamie Madill1b94d432015-08-07 13:23:23 -0400534 mDirtyBits.set(DIRTY_BIT_STENCIL_OPS_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400535}
536
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700537void State::setStencilBackOperations(GLenum stencilBackFail,
538 GLenum stencilBackPassDepthFail,
539 GLenum stencilBackPassDepthPass)
Shannon Woods53a94a82014-06-24 15:20:36 -0400540{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700541 mDepthStencil.stencilBackFail = stencilBackFail;
Shannon Woods53a94a82014-06-24 15:20:36 -0400542 mDepthStencil.stencilBackPassDepthFail = stencilBackPassDepthFail;
543 mDepthStencil.stencilBackPassDepthPass = stencilBackPassDepthPass;
Jamie Madill1b94d432015-08-07 13:23:23 -0400544 mDirtyBits.set(DIRTY_BIT_STENCIL_OPS_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400545}
546
547GLint State::getStencilRef() const
548{
549 return mStencilRef;
550}
551
552GLint State::getStencilBackRef() const
553{
554 return mStencilBackRef;
555}
556
557bool State::isPolygonOffsetFillEnabled() const
558{
559 return mRasterizer.polygonOffsetFill;
560}
561
562void State::setPolygonOffsetFill(bool enabled)
563{
Jamie Madill1b94d432015-08-07 13:23:23 -0400564 mRasterizer.polygonOffsetFill = enabled;
565 mDirtyBits.set(DIRTY_BIT_POLYGON_OFFSET_FILL_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400566}
567
568void State::setPolygonOffsetParams(GLfloat factor, GLfloat units)
569{
570 // An application can pass NaN values here, so handle this gracefully
571 mRasterizer.polygonOffsetFactor = factor != factor ? 0.0f : factor;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700572 mRasterizer.polygonOffsetUnits = units != units ? 0.0f : units;
Jamie Madill1b94d432015-08-07 13:23:23 -0400573 mDirtyBits.set(DIRTY_BIT_POLYGON_OFFSET);
Shannon Woods53a94a82014-06-24 15:20:36 -0400574}
575
576bool State::isSampleAlphaToCoverageEnabled() const
577{
578 return mBlend.sampleAlphaToCoverage;
579}
580
581void State::setSampleAlphaToCoverage(bool enabled)
582{
583 mBlend.sampleAlphaToCoverage = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400584 mDirtyBits.set(DIRTY_BIT_SAMPLE_ALPHA_TO_COVERAGE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400585}
586
587bool State::isSampleCoverageEnabled() const
588{
589 return mSampleCoverage;
590}
591
592void State::setSampleCoverage(bool enabled)
593{
594 mSampleCoverage = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400595 mDirtyBits.set(DIRTY_BIT_SAMPLE_COVERAGE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400596}
597
598void State::setSampleCoverageParams(GLclampf value, bool invert)
599{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700600 mSampleCoverageValue = value;
Shannon Woods53a94a82014-06-24 15:20:36 -0400601 mSampleCoverageInvert = invert;
Jamie Madill1b94d432015-08-07 13:23:23 -0400602 mDirtyBits.set(DIRTY_BIT_SAMPLE_COVERAGE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400603}
604
Geoff Lang0fbb6002015-04-16 11:11:53 -0400605GLclampf State::getSampleCoverageValue() const
Shannon Woods53a94a82014-06-24 15:20:36 -0400606{
Geoff Lang0fbb6002015-04-16 11:11:53 -0400607 return mSampleCoverageValue;
608}
Shannon Woods53a94a82014-06-24 15:20:36 -0400609
Geoff Lang0fbb6002015-04-16 11:11:53 -0400610bool State::getSampleCoverageInvert() const
611{
612 return mSampleCoverageInvert;
Shannon Woods53a94a82014-06-24 15:20:36 -0400613}
614
Jiawei Shaodb342272017-09-27 10:21:45 +0800615bool State::isSampleMaskEnabled() const
616{
617 return mSampleMask;
618}
619
620void State::setSampleMaskEnabled(bool enabled)
621{
622 mSampleMask = enabled;
623 mDirtyBits.set(DIRTY_BIT_SAMPLE_MASK_ENABLED);
624}
625
626void State::setSampleMaskParams(GLuint maskNumber, GLbitfield mask)
627{
628 ASSERT(maskNumber < mMaxSampleMaskWords);
629 mSampleMaskValues[maskNumber] = mask;
Jamie Madillc67323a2017-11-02 23:11:41 -0400630 // TODO(jmadill): Use a child dirty bit if we ever use more than two words.
631 mDirtyBits.set(DIRTY_BIT_SAMPLE_MASK);
Jiawei Shaodb342272017-09-27 10:21:45 +0800632}
633
634GLbitfield State::getSampleMaskWord(GLuint maskNumber) const
635{
636 ASSERT(maskNumber < mMaxSampleMaskWords);
637 return mSampleMaskValues[maskNumber];
638}
639
640GLuint State::getMaxSampleMaskWords() const
641{
642 return mMaxSampleMaskWords;
643}
644
Sami Väisänen74c23472016-05-09 17:30:30 +0300645void State::setSampleAlphaToOne(bool enabled)
646{
647 mSampleAlphaToOne = enabled;
648 mDirtyBits.set(DIRTY_BIT_SAMPLE_ALPHA_TO_ONE);
649}
650
651bool State::isSampleAlphaToOneEnabled() const
652{
653 return mSampleAlphaToOne;
654}
655
656void State::setMultisampling(bool enabled)
657{
658 mMultiSampling = enabled;
659 mDirtyBits.set(DIRTY_BIT_MULTISAMPLING);
660}
661
662bool State::isMultisamplingEnabled() const
663{
664 return mMultiSampling;
665}
666
Shannon Woods53a94a82014-06-24 15:20:36 -0400667bool State::isScissorTestEnabled() const
668{
669 return mScissorTest;
670}
671
672void State::setScissorTest(bool enabled)
673{
674 mScissorTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400675 mDirtyBits.set(DIRTY_BIT_SCISSOR_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400676}
677
678void State::setScissorParams(GLint x, GLint y, GLsizei width, GLsizei height)
679{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700680 mScissor.x = x;
681 mScissor.y = y;
682 mScissor.width = width;
Shannon Woods53a94a82014-06-24 15:20:36 -0400683 mScissor.height = height;
Jamie Madill1b94d432015-08-07 13:23:23 -0400684 mDirtyBits.set(DIRTY_BIT_SCISSOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400685}
686
687const Rectangle &State::getScissor() const
688{
689 return mScissor;
690}
691
692bool State::isDitherEnabled() const
693{
694 return mBlend.dither;
695}
696
697void State::setDither(bool enabled)
698{
699 mBlend.dither = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400700 mDirtyBits.set(DIRTY_BIT_DITHER_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400701}
702
Jamie Madillb4b53c52015-02-03 15:22:48 -0500703bool State::isPrimitiveRestartEnabled() const
704{
705 return mPrimitiveRestart;
706}
707
708void State::setPrimitiveRestart(bool enabled)
709{
710 mPrimitiveRestart = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400711 mDirtyBits.set(DIRTY_BIT_PRIMITIVE_RESTART_ENABLED);
Jamie Madillb4b53c52015-02-03 15:22:48 -0500712}
713
Shannon Woods53a94a82014-06-24 15:20:36 -0400714void State::setEnableFeature(GLenum feature, bool enabled)
715{
716 switch (feature)
717 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700718 case GL_MULTISAMPLE_EXT:
719 setMultisampling(enabled);
720 break;
721 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
722 setSampleAlphaToOne(enabled);
723 break;
724 case GL_CULL_FACE:
725 setCullFace(enabled);
726 break;
727 case GL_POLYGON_OFFSET_FILL:
728 setPolygonOffsetFill(enabled);
729 break;
730 case GL_SAMPLE_ALPHA_TO_COVERAGE:
731 setSampleAlphaToCoverage(enabled);
732 break;
733 case GL_SAMPLE_COVERAGE:
734 setSampleCoverage(enabled);
735 break;
736 case GL_SCISSOR_TEST:
737 setScissorTest(enabled);
738 break;
739 case GL_STENCIL_TEST:
740 setStencilTest(enabled);
741 break;
742 case GL_DEPTH_TEST:
743 setDepthTest(enabled);
744 break;
745 case GL_BLEND:
746 setBlend(enabled);
747 break;
748 case GL_DITHER:
749 setDither(enabled);
750 break;
751 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
752 setPrimitiveRestart(enabled);
753 break;
754 case GL_RASTERIZER_DISCARD:
755 setRasterizerDiscard(enabled);
756 break;
757 case GL_SAMPLE_MASK:
758 setSampleMaskEnabled(enabled);
759 break;
760 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
761 mDebug.setOutputSynchronous(enabled);
762 break;
763 case GL_DEBUG_OUTPUT:
764 mDebug.setOutputEnabled(enabled);
765 break;
766 case GL_FRAMEBUFFER_SRGB_EXT:
767 setFramebufferSRGB(enabled);
768 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -0700769
770 // GLES1 emulation
771 case GL_ALPHA_TEST:
772 mGLES1State.mAlphaTestEnabled = enabled;
773 break;
774
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700775 default:
776 UNREACHABLE();
Shannon Woods53a94a82014-06-24 15:20:36 -0400777 }
778}
779
Jamie Madilldfde6ab2016-06-09 07:07:18 -0700780bool State::getEnableFeature(GLenum feature) const
Shannon Woods53a94a82014-06-24 15:20:36 -0400781{
782 switch (feature)
783 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700784 case GL_MULTISAMPLE_EXT:
785 return isMultisamplingEnabled();
786 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
787 return isSampleAlphaToOneEnabled();
788 case GL_CULL_FACE:
789 return isCullFaceEnabled();
790 case GL_POLYGON_OFFSET_FILL:
791 return isPolygonOffsetFillEnabled();
792 case GL_SAMPLE_ALPHA_TO_COVERAGE:
793 return isSampleAlphaToCoverageEnabled();
794 case GL_SAMPLE_COVERAGE:
795 return isSampleCoverageEnabled();
796 case GL_SCISSOR_TEST:
797 return isScissorTestEnabled();
798 case GL_STENCIL_TEST:
799 return isStencilTestEnabled();
800 case GL_DEPTH_TEST:
801 return isDepthTestEnabled();
802 case GL_BLEND:
803 return isBlendEnabled();
804 case GL_DITHER:
805 return isDitherEnabled();
806 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
807 return isPrimitiveRestartEnabled();
808 case GL_RASTERIZER_DISCARD:
809 return isRasterizerDiscardEnabled();
810 case GL_SAMPLE_MASK:
811 return isSampleMaskEnabled();
812 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
813 return mDebug.isOutputSynchronous();
814 case GL_DEBUG_OUTPUT:
815 return mDebug.isOutputEnabled();
816 case GL_BIND_GENERATES_RESOURCE_CHROMIUM:
817 return isBindGeneratesResourceEnabled();
818 case GL_CLIENT_ARRAYS_ANGLE:
819 return areClientArraysEnabled();
820 case GL_FRAMEBUFFER_SRGB_EXT:
821 return getFramebufferSRGB();
822 case GL_ROBUST_RESOURCE_INITIALIZATION_ANGLE:
823 return mRobustResourceInit;
824 case GL_PROGRAM_CACHE_ENABLED_ANGLE:
825 return mProgramBinaryCacheEnabled;
Jamie Madillc43be722017-07-13 16:22:14 -0400826
Lingfeng Yang13b708f2018-03-21 12:14:10 -0700827 // GLES1 emulation
828 case GL_ALPHA_TEST:
829 return mGLES1State.mAlphaTestEnabled;
Lingfeng Yang01074432018-04-16 10:19:51 -0700830 case GL_VERTEX_ARRAY:
831 return mGLES1State.mVertexArrayEnabled;
832 case GL_NORMAL_ARRAY:
833 return mGLES1State.mNormalArrayEnabled;
834 case GL_COLOR_ARRAY:
835 return mGLES1State.mColorArrayEnabled;
836 case GL_POINT_SIZE_ARRAY_OES:
837 return mGLES1State.mPointSizeArrayEnabled;
838 case GL_TEXTURE_COORD_ARRAY:
839 return mGLES1State.mTexCoordArrayEnabled[mGLES1State.mClientActiveTexture];
Lingfeng Yang13b708f2018-03-21 12:14:10 -0700840
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700841 default:
842 UNREACHABLE();
843 return false;
Shannon Woods53a94a82014-06-24 15:20:36 -0400844 }
845}
846
847void State::setLineWidth(GLfloat width)
848{
849 mLineWidth = width;
Jamie Madill1b94d432015-08-07 13:23:23 -0400850 mDirtyBits.set(DIRTY_BIT_LINE_WIDTH);
Shannon Woods53a94a82014-06-24 15:20:36 -0400851}
852
Geoff Lang4b3f4162015-04-16 13:22:05 -0400853float State::getLineWidth() const
854{
855 return mLineWidth;
856}
857
Shannon Woods53a94a82014-06-24 15:20:36 -0400858void State::setGenerateMipmapHint(GLenum hint)
859{
860 mGenerateMipmapHint = hint;
Jamie Madill1b94d432015-08-07 13:23:23 -0400861 mDirtyBits.set(DIRTY_BIT_GENERATE_MIPMAP_HINT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400862}
863
864void State::setFragmentShaderDerivativeHint(GLenum hint)
865{
866 mFragmentShaderDerivativeHint = hint;
Jamie Madill1b94d432015-08-07 13:23:23 -0400867 mDirtyBits.set(DIRTY_BIT_SHADER_DERIVATIVE_HINT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400868 // TODO: Propagate the hint to shader translator so we can write
869 // ddx, ddx_coarse, or ddx_fine depending on the hint.
870 // Ignore for now. It is valid for implementations to ignore hint.
871}
872
Geoff Langf41a7152016-09-19 15:11:17 -0400873bool State::isBindGeneratesResourceEnabled() const
874{
875 return mBindGeneratesResource;
876}
877
Geoff Langfeb8c682017-02-13 16:07:35 -0500878bool State::areClientArraysEnabled() const
879{
880 return mClientArraysEnabled;
881}
882
Shannon Woods53a94a82014-06-24 15:20:36 -0400883void State::setViewportParams(GLint x, GLint y, GLsizei width, GLsizei height)
884{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700885 mViewport.x = x;
886 mViewport.y = y;
887 mViewport.width = width;
Shannon Woods53a94a82014-06-24 15:20:36 -0400888 mViewport.height = height;
Jamie Madill1b94d432015-08-07 13:23:23 -0400889 mDirtyBits.set(DIRTY_BIT_VIEWPORT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400890}
891
892const Rectangle &State::getViewport() const
893{
894 return mViewport;
895}
896
897void State::setActiveSampler(unsigned int active)
898{
899 mActiveSampler = active;
900}
901
902unsigned int State::getActiveSampler() const
903{
Cooper Partin4d61f7e2015-08-12 10:56:50 -0700904 return static_cast<unsigned int>(mActiveSampler);
Shannon Woods53a94a82014-06-24 15:20:36 -0400905}
906
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800907void State::setSamplerTexture(const Context *context, TextureType type, Texture *texture)
Shannon Woods53a94a82014-06-24 15:20:36 -0400908{
Jamie Madill4928b7c2017-06-20 12:57:39 -0400909 mSamplerTextures[type][mActiveSampler].set(context, texture);
Jamie Madill81c2e252017-09-09 23:32:46 -0400910 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
911 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Shannon Woods53a94a82014-06-24 15:20:36 -0400912}
913
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800914Texture *State::getTargetTexture(TextureType type) const
Jamie Madillc29968b2016-01-20 11:17:23 -0500915{
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800916 return getSamplerTexture(static_cast<unsigned int>(mActiveSampler), type);
Jamie Madillc29968b2016-01-20 11:17:23 -0500917}
918
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800919Texture *State::getSamplerTexture(unsigned int sampler, TextureType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -0400920{
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800921 ASSERT(sampler < mSamplerTextures[type].size());
922 return mSamplerTextures[type][sampler].get();
Shannon Woods53a94a82014-06-24 15:20:36 -0400923}
924
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800925GLuint State::getSamplerTextureId(unsigned int sampler, TextureType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -0400926{
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800927 ASSERT(sampler < mSamplerTextures[type].size());
928 return mSamplerTextures[type][sampler].id();
Shannon Woods53a94a82014-06-24 15:20:36 -0400929}
930
Jamie Madilla02315b2017-02-23 14:14:47 -0500931void State::detachTexture(const Context *context, const TextureMap &zeroTextures, GLuint texture)
Shannon Woods53a94a82014-06-24 15:20:36 -0400932{
933 // Textures have a detach method on State rather than a simple
934 // removeBinding, because the zero/null texture objects are managed
935 // separately, and don't have to go through the Context's maps or
936 // the ResourceManager.
937
938 // [OpenGL ES 2.0.24] section 3.8 page 84:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700939 // If a texture object is deleted, it is as if all texture units which are bound to that texture
940 // object are rebound to texture object zero
Shannon Woods53a94a82014-06-24 15:20:36 -0400941
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800942 for (TextureType type : angle::AllEnums<TextureType>())
Shannon Woods53a94a82014-06-24 15:20:36 -0400943 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800944 TextureBindingVector &textureVector = mSamplerTextures[type];
Jamie Madill81c2e252017-09-09 23:32:46 -0400945 for (BindingPointer<Texture> &binding : textureVector)
Shannon Woods53a94a82014-06-24 15:20:36 -0400946 {
Geoff Lang76b10c92014-09-05 16:28:14 -0400947 if (binding.id() == texture)
Shannon Woods53a94a82014-06-24 15:20:36 -0400948 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800949 Texture *zeroTexture = zeroTextures[type].get();
950 ASSERT(zeroTexture != nullptr);
Jamie Madille6382c32014-11-07 15:05:26 -0500951 // Zero textures are the "default" textures instead of NULL
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800952 binding.set(context, zeroTexture);
Jamie Madill81c2e252017-09-09 23:32:46 -0400953 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
Shannon Woods53a94a82014-06-24 15:20:36 -0400954 }
955 }
956 }
957
Xinghua Cao65ec0b22017-03-28 16:10:52 +0800958 for (auto &bindingImageUnit : mImageUnits)
959 {
960 if (bindingImageUnit.texture.id() == texture)
961 {
962 bindingImageUnit.texture.set(context, nullptr);
963 bindingImageUnit.level = 0;
964 bindingImageUnit.layered = false;
965 bindingImageUnit.layer = 0;
966 bindingImageUnit.access = GL_READ_ONLY;
967 bindingImageUnit.format = GL_R32UI;
968 break;
969 }
970 }
971
Shannon Woods53a94a82014-06-24 15:20:36 -0400972 // [OpenGL ES 2.0.24] section 4.4 page 112:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700973 // If a texture object is deleted while its image is attached to the currently bound
974 // framebuffer, then it is as if Texture2DAttachment had been called, with a texture of 0, for
975 // each attachment point to which this image was attached in the currently bound framebuffer.
Shannon Woods53a94a82014-06-24 15:20:36 -0400976
Jamie Madill8693bdb2017-09-02 15:32:14 -0400977 if (mReadFramebuffer && mReadFramebuffer->detachTexture(context, texture))
Shannon Woods53a94a82014-06-24 15:20:36 -0400978 {
Jamie Madill8693bdb2017-09-02 15:32:14 -0400979 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
Shannon Woods53a94a82014-06-24 15:20:36 -0400980 }
981
Jamie Madill8693bdb2017-09-02 15:32:14 -0400982 if (mDrawFramebuffer && mDrawFramebuffer->detachTexture(context, texture))
Shannon Woods53a94a82014-06-24 15:20:36 -0400983 {
Jamie Madill8693bdb2017-09-02 15:32:14 -0400984 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
Shannon Woods53a94a82014-06-24 15:20:36 -0400985 }
986}
987
Jamie Madill4928b7c2017-06-20 12:57:39 -0400988void State::initializeZeroTextures(const Context *context, const TextureMap &zeroTextures)
Jamie Madille6382c32014-11-07 15:05:26 -0500989{
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800990 for (TextureType type : angle::AllEnums<TextureType>())
Jamie Madille6382c32014-11-07 15:05:26 -0500991 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800992 for (size_t textureUnit = 0; textureUnit < mSamplerTextures[type].size(); ++textureUnit)
Jamie Madille6382c32014-11-07 15:05:26 -0500993 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800994 mSamplerTextures[type][textureUnit].set(context, zeroTextures[type].get());
Jamie Madille6382c32014-11-07 15:05:26 -0500995 }
996 }
997}
998
Jamie Madill4928b7c2017-06-20 12:57:39 -0400999void State::setSamplerBinding(const Context *context, GLuint textureUnit, Sampler *sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001000{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001001 mSamplers[textureUnit].set(context, sampler);
Jamie Madill81c2e252017-09-09 23:32:46 -04001002 mDirtyBits.set(DIRTY_BIT_SAMPLER_BINDINGS);
1003 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Shannon Woods53a94a82014-06-24 15:20:36 -04001004}
1005
1006GLuint State::getSamplerId(GLuint textureUnit) const
1007{
Geoff Lang76b10c92014-09-05 16:28:14 -04001008 ASSERT(textureUnit < mSamplers.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001009 return mSamplers[textureUnit].id();
1010}
1011
1012Sampler *State::getSampler(GLuint textureUnit) const
1013{
1014 return mSamplers[textureUnit].get();
1015}
1016
Jamie Madill4928b7c2017-06-20 12:57:39 -04001017void State::detachSampler(const Context *context, GLuint sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001018{
1019 // [OpenGL ES 3.0.2] section 3.8.2 pages 123-124:
1020 // If a sampler object that is currently bound to one or more texture units is
1021 // deleted, it is as though BindSampler is called once for each texture unit to
1022 // which the sampler is bound, with unit set to the texture unit and sampler set to zero.
Jamie Madill81c2e252017-09-09 23:32:46 -04001023 for (BindingPointer<Sampler> &samplerBinding : mSamplers)
Shannon Woods53a94a82014-06-24 15:20:36 -04001024 {
Geoff Lang76b10c92014-09-05 16:28:14 -04001025 if (samplerBinding.id() == sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001026 {
Jamie Madill4928b7c2017-06-20 12:57:39 -04001027 samplerBinding.set(context, nullptr);
Jamie Madill81c2e252017-09-09 23:32:46 -04001028 mDirtyBits.set(DIRTY_BIT_SAMPLER_BINDINGS);
Shannon Woods53a94a82014-06-24 15:20:36 -04001029 }
1030 }
1031}
1032
Jamie Madill4928b7c2017-06-20 12:57:39 -04001033void State::setRenderbufferBinding(const Context *context, Renderbuffer *renderbuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001034{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001035 mRenderbuffer.set(context, renderbuffer);
Jamie Madill8693bdb2017-09-02 15:32:14 -04001036 mDirtyBits.set(DIRTY_BIT_RENDERBUFFER_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001037}
1038
1039GLuint State::getRenderbufferId() const
1040{
1041 return mRenderbuffer.id();
1042}
1043
Jamie Madilldfde6ab2016-06-09 07:07:18 -07001044Renderbuffer *State::getCurrentRenderbuffer() const
Shannon Woods53a94a82014-06-24 15:20:36 -04001045{
1046 return mRenderbuffer.get();
1047}
1048
Jamie Madilla02315b2017-02-23 14:14:47 -05001049void State::detachRenderbuffer(const Context *context, GLuint renderbuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001050{
1051 // [OpenGL ES 2.0.24] section 4.4 page 109:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001052 // If a renderbuffer that is currently bound to RENDERBUFFER is deleted, it is as though
1053 // BindRenderbuffer had been executed with the target RENDERBUFFER and name of zero.
Shannon Woods53a94a82014-06-24 15:20:36 -04001054
1055 if (mRenderbuffer.id() == renderbuffer)
1056 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001057 setRenderbufferBinding(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001058 }
1059
1060 // [OpenGL ES 2.0.24] section 4.4 page 111:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001061 // If a renderbuffer object is deleted while its image is attached to the currently bound
1062 // framebuffer, then it is as if FramebufferRenderbuffer had been called, with a renderbuffer of
1063 // 0, for each attachment point to which this image was attached in the currently bound
1064 // framebuffer.
Shannon Woods53a94a82014-06-24 15:20:36 -04001065
1066 Framebuffer *readFramebuffer = mReadFramebuffer;
1067 Framebuffer *drawFramebuffer = mDrawFramebuffer;
1068
Jamie Madill8693bdb2017-09-02 15:32:14 -04001069 if (readFramebuffer && readFramebuffer->detachRenderbuffer(context, renderbuffer))
Shannon Woods53a94a82014-06-24 15:20:36 -04001070 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001071 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
Shannon Woods53a94a82014-06-24 15:20:36 -04001072 }
1073
1074 if (drawFramebuffer && drawFramebuffer != readFramebuffer)
1075 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001076 if (drawFramebuffer->detachRenderbuffer(context, renderbuffer))
1077 {
1078 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
1079 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001080 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001081}
1082
1083void State::setReadFramebufferBinding(Framebuffer *framebuffer)
1084{
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001085 if (mReadFramebuffer == framebuffer)
1086 return;
1087
Shannon Woods53a94a82014-06-24 15:20:36 -04001088 mReadFramebuffer = framebuffer;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001089 mDirtyBits.set(DIRTY_BIT_READ_FRAMEBUFFER_BINDING);
1090
1091 if (mReadFramebuffer && mReadFramebuffer->hasAnyDirtyBit())
1092 {
1093 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
1094 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001095}
1096
1097void State::setDrawFramebufferBinding(Framebuffer *framebuffer)
1098{
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001099 if (mDrawFramebuffer == framebuffer)
1100 return;
1101
Shannon Woods53a94a82014-06-24 15:20:36 -04001102 mDrawFramebuffer = framebuffer;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001103 mDirtyBits.set(DIRTY_BIT_DRAW_FRAMEBUFFER_BINDING);
1104
1105 if (mDrawFramebuffer && mDrawFramebuffer->hasAnyDirtyBit())
1106 {
1107 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
1108 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001109}
1110
1111Framebuffer *State::getTargetFramebuffer(GLenum target) const
1112{
1113 switch (target)
1114 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001115 case GL_READ_FRAMEBUFFER_ANGLE:
1116 return mReadFramebuffer;
1117 case GL_DRAW_FRAMEBUFFER_ANGLE:
1118 case GL_FRAMEBUFFER:
1119 return mDrawFramebuffer;
1120 default:
1121 UNREACHABLE();
Yunchao Hef81ce4a2017-04-24 10:49:17 +08001122 return nullptr;
Shannon Woods53a94a82014-06-24 15:20:36 -04001123 }
1124}
1125
Jamie Madill51f40ec2016-06-15 14:06:00 -04001126Framebuffer *State::getReadFramebuffer() const
Shannon Woods53a94a82014-06-24 15:20:36 -04001127{
1128 return mReadFramebuffer;
1129}
1130
Jamie Madill51f40ec2016-06-15 14:06:00 -04001131Framebuffer *State::getDrawFramebuffer() const
Shannon Woods53a94a82014-06-24 15:20:36 -04001132{
1133 return mDrawFramebuffer;
1134}
1135
1136bool State::removeReadFramebufferBinding(GLuint framebuffer)
1137{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001138 if (mReadFramebuffer != nullptr && mReadFramebuffer->id() == framebuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001139 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001140 setReadFramebufferBinding(nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001141 return true;
1142 }
1143
1144 return false;
1145}
1146
1147bool State::removeDrawFramebufferBinding(GLuint framebuffer)
1148{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001149 if (mReadFramebuffer != nullptr && mDrawFramebuffer->id() == framebuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001150 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001151 setDrawFramebufferBinding(nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001152 return true;
1153 }
1154
1155 return false;
1156}
1157
1158void State::setVertexArrayBinding(VertexArray *vertexArray)
1159{
James Darpiniane8a93c62018-01-04 18:02:24 -08001160 if (mVertexArray == vertexArray)
1161 return;
1162 if (mVertexArray)
1163 mVertexArray->onBindingChanged(false);
Shannon Woods53a94a82014-06-24 15:20:36 -04001164 mVertexArray = vertexArray;
James Darpiniane8a93c62018-01-04 18:02:24 -08001165 if (vertexArray)
1166 vertexArray->onBindingChanged(true);
Jamie Madill0b9e9032015-08-17 11:51:52 +00001167 mDirtyBits.set(DIRTY_BIT_VERTEX_ARRAY_BINDING);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001168
1169 if (mVertexArray && mVertexArray->hasAnyDirtyBit())
1170 {
1171 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1172 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001173}
1174
1175GLuint State::getVertexArrayId() const
1176{
Yunchao He4f285442017-04-21 12:15:49 +08001177 ASSERT(mVertexArray != nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001178 return mVertexArray->id();
1179}
1180
1181VertexArray *State::getVertexArray() const
1182{
Yunchao He4f285442017-04-21 12:15:49 +08001183 ASSERT(mVertexArray != nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001184 return mVertexArray;
1185}
1186
1187bool State::removeVertexArrayBinding(GLuint vertexArray)
1188{
James Darpiniane8a93c62018-01-04 18:02:24 -08001189 if (mVertexArray && mVertexArray->id() == vertexArray)
Shannon Woods53a94a82014-06-24 15:20:36 -04001190 {
James Darpiniane8a93c62018-01-04 18:02:24 -08001191 mVertexArray->onBindingChanged(false);
Yunchao Hed7297bf2017-04-19 15:27:10 +08001192 mVertexArray = nullptr;
Jamie Madill0b9e9032015-08-17 11:51:52 +00001193 mDirtyBits.set(DIRTY_BIT_VERTEX_ARRAY_BINDING);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001194 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001195 return true;
1196 }
1197
1198 return false;
1199}
1200
Jamie Madill4928b7c2017-06-20 12:57:39 -04001201void State::bindVertexBuffer(const Context *context,
1202 GLuint bindingIndex,
Shao80957d92017-02-20 21:25:59 +08001203 Buffer *boundBuffer,
1204 GLintptr offset,
1205 GLsizei stride)
1206{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001207 getVertexArray()->bindVertexBuffer(context, bindingIndex, boundBuffer, offset, stride);
Shao80957d92017-02-20 21:25:59 +08001208 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1209}
1210
Shaodde78e82017-05-22 14:13:27 +08001211void State::setVertexAttribBinding(const Context *context, GLuint attribIndex, GLuint bindingIndex)
Shao80957d92017-02-20 21:25:59 +08001212{
Shaodde78e82017-05-22 14:13:27 +08001213 getVertexArray()->setVertexAttribBinding(context, attribIndex, bindingIndex);
Shao80957d92017-02-20 21:25:59 +08001214 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1215}
1216
1217void State::setVertexAttribFormat(GLuint attribIndex,
1218 GLint size,
1219 GLenum type,
1220 bool normalized,
1221 bool pureInteger,
1222 GLuint relativeOffset)
1223{
1224 getVertexArray()->setVertexAttribFormat(attribIndex, size, type, normalized, pureInteger,
1225 relativeOffset);
1226 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1227}
1228
1229void State::setVertexBindingDivisor(GLuint bindingIndex, GLuint divisor)
1230{
1231 getVertexArray()->setVertexBindingDivisor(bindingIndex, divisor);
1232 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1233}
1234
Jamie Madill6c1f6712017-02-14 19:08:04 -05001235void State::setProgram(const Context *context, Program *newProgram)
Shannon Woods53a94a82014-06-24 15:20:36 -04001236{
Geoff Lang7dd2e102014-11-10 15:19:26 -05001237 if (mProgram != newProgram)
Shannon Woods53a94a82014-06-24 15:20:36 -04001238 {
Geoff Lang7dd2e102014-11-10 15:19:26 -05001239 if (mProgram)
1240 {
Jamie Madill6c1f6712017-02-14 19:08:04 -05001241 mProgram->release(context);
Geoff Lang7dd2e102014-11-10 15:19:26 -05001242 }
1243
1244 mProgram = newProgram;
1245
1246 if (mProgram)
1247 {
1248 newProgram->addRef();
Jamie Madill81c2e252017-09-09 23:32:46 -04001249 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Geoff Lang7dd2e102014-11-10 15:19:26 -05001250 }
Jamie Madilla779b612017-07-24 11:46:05 -04001251 mDirtyBits.set(DIRTY_BIT_PROGRAM_EXECUTABLE);
1252 mDirtyBits.set(DIRTY_BIT_PROGRAM_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001253 }
1254}
1255
Geoff Lang7dd2e102014-11-10 15:19:26 -05001256Program *State::getProgram() const
Shannon Woods53a94a82014-06-24 15:20:36 -04001257{
Geoff Lang7dd2e102014-11-10 15:19:26 -05001258 return mProgram;
Shannon Woods53a94a82014-06-24 15:20:36 -04001259}
1260
Jamie Madill4928b7c2017-06-20 12:57:39 -04001261void State::setTransformFeedbackBinding(const Context *context,
1262 TransformFeedback *transformFeedback)
Shannon Woods53a94a82014-06-24 15:20:36 -04001263{
James Darpiniane8a93c62018-01-04 18:02:24 -08001264 if (transformFeedback == mTransformFeedback.get())
1265 return;
1266 if (mTransformFeedback.get())
1267 mTransformFeedback->onBindingChanged(false);
Jamie Madill4928b7c2017-06-20 12:57:39 -04001268 mTransformFeedback.set(context, transformFeedback);
James Darpiniane8a93c62018-01-04 18:02:24 -08001269 if (mTransformFeedback.get())
1270 mTransformFeedback->onBindingChanged(true);
Geoff Langded79232017-11-28 15:21:11 -05001271 mDirtyBits.set(DIRTY_BIT_TRANSFORM_FEEDBACK_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001272}
1273
1274TransformFeedback *State::getCurrentTransformFeedback() const
1275{
1276 return mTransformFeedback.get();
1277}
1278
Gregoire Payen de La Garanderie52742022015-02-04 14:55:39 +00001279bool State::isTransformFeedbackActiveUnpaused() const
1280{
Jamie Madill81c2e252017-09-09 23:32:46 -04001281 TransformFeedback *curTransformFeedback = getCurrentTransformFeedback();
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001282 return curTransformFeedback && curTransformFeedback->isActive() &&
1283 !curTransformFeedback->isPaused();
Gregoire Payen de La Garanderie52742022015-02-04 14:55:39 +00001284}
1285
Jamie Madill4928b7c2017-06-20 12:57:39 -04001286bool State::removeTransformFeedbackBinding(const Context *context, GLuint transformFeedback)
Shannon Woods53a94a82014-06-24 15:20:36 -04001287{
1288 if (mTransformFeedback.id() == transformFeedback)
1289 {
James Darpiniane8a93c62018-01-04 18:02:24 -08001290 if (mTransformFeedback.get())
1291 mTransformFeedback->onBindingChanged(false);
Jamie Madill4928b7c2017-06-20 12:57:39 -04001292 mTransformFeedback.set(context, nullptr);
Corentin Walleza2257da2016-04-19 16:43:12 -04001293 return true;
Shannon Woods53a94a82014-06-24 15:20:36 -04001294 }
Corentin Walleza2257da2016-04-19 16:43:12 -04001295
1296 return false;
Shannon Woods53a94a82014-06-24 15:20:36 -04001297}
1298
Yunchao Hea336b902017-08-02 16:05:21 +08001299void State::setProgramPipelineBinding(const Context *context, ProgramPipeline *pipeline)
1300{
1301 mProgramPipeline.set(context, pipeline);
1302}
1303
1304void State::detachProgramPipeline(const Context *context, GLuint pipeline)
1305{
1306 mProgramPipeline.set(context, nullptr);
1307}
1308
Olli Etuahobbf1c102016-06-28 13:31:33 +03001309bool State::isQueryActive(const GLenum type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001310{
Ian Ewell3ffd78b2016-01-22 16:09:42 -05001311 for (auto &iter : mActiveQueries)
Shannon Woods53a94a82014-06-24 15:20:36 -04001312 {
Olli Etuahobbf1c102016-06-28 13:31:33 +03001313 const Query *query = iter.second.get();
1314 if (query != nullptr && ActiveQueryType(query->getType()) == ActiveQueryType(type))
Ian Ewell3ffd78b2016-01-22 16:09:42 -05001315 {
1316 return true;
1317 }
1318 }
1319
1320 return false;
1321}
1322
1323bool State::isQueryActive(Query *query) const
1324{
1325 for (auto &iter : mActiveQueries)
1326 {
1327 if (iter.second.get() == query)
Shannon Woods53a94a82014-06-24 15:20:36 -04001328 {
1329 return true;
1330 }
1331 }
1332
1333 return false;
1334}
1335
Jamie Madill4928b7c2017-06-20 12:57:39 -04001336void State::setActiveQuery(const Context *context, GLenum target, Query *query)
Shannon Woods53a94a82014-06-24 15:20:36 -04001337{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001338 mActiveQueries[target].set(context, query);
Shannon Woods53a94a82014-06-24 15:20:36 -04001339}
1340
1341GLuint State::getActiveQueryId(GLenum target) const
1342{
1343 const Query *query = getActiveQuery(target);
1344 return (query ? query->id() : 0u);
1345}
1346
1347Query *State::getActiveQuery(GLenum target) const
1348{
Jamie Madill5864ac22015-01-12 14:43:07 -05001349 const auto it = mActiveQueries.find(target);
Shannon Woods53a94a82014-06-24 15:20:36 -04001350
Jamie Madill5864ac22015-01-12 14:43:07 -05001351 // All query types should already exist in the activeQueries map
1352 ASSERT(it != mActiveQueries.end());
1353
1354 return it->second.get();
Shannon Woods53a94a82014-06-24 15:20:36 -04001355}
1356
Corentin Wallez336129f2017-10-17 15:55:40 -04001357void State::setBufferBinding(const Context *context, BufferBinding target, Buffer *buffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001358{
Corentin Wallez336129f2017-10-17 15:55:40 -04001359 switch (target)
1360 {
1361 case BufferBinding::PixelPack:
James Darpiniane8a93c62018-01-04 18:02:24 -08001362 UpdateBufferBinding(context, &mBoundBuffers[target], buffer, target);
Corentin Wallez336129f2017-10-17 15:55:40 -04001363 mDirtyBits.set(DIRTY_BIT_PACK_BUFFER_BINDING);
1364 break;
1365 case BufferBinding::PixelUnpack:
James Darpiniane8a93c62018-01-04 18:02:24 -08001366 UpdateBufferBinding(context, &mBoundBuffers[target], buffer, target);
Corentin Wallez336129f2017-10-17 15:55:40 -04001367 mDirtyBits.set(DIRTY_BIT_UNPACK_BUFFER_BINDING);
1368 break;
1369 case BufferBinding::DrawIndirect:
James Darpiniane8a93c62018-01-04 18:02:24 -08001370 UpdateBufferBinding(context, &mBoundBuffers[target], buffer, target);
Corentin Wallez336129f2017-10-17 15:55:40 -04001371 mDirtyBits.set(DIRTY_BIT_DRAW_INDIRECT_BUFFER_BINDING);
1372 break;
Qin Jiajiaa98a2812017-11-30 18:12:06 +08001373 case BufferBinding::DispatchIndirect:
James Darpiniane8a93c62018-01-04 18:02:24 -08001374 UpdateBufferBinding(context, &mBoundBuffers[target], buffer, target);
Qin Jiajiaa98a2812017-11-30 18:12:06 +08001375 mDirtyBits.set(DIRTY_BIT_DISPATCH_INDIRECT_BUFFER_BINDING);
1376 break;
Corentin Wallez336129f2017-10-17 15:55:40 -04001377 case BufferBinding::ElementArray:
1378 getVertexArray()->setElementArrayBuffer(context, buffer);
1379 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1380 break;
Xinghua Cao10a4d432017-11-28 14:46:26 +08001381 case BufferBinding::ShaderStorage:
James Darpiniane8a93c62018-01-04 18:02:24 -08001382 UpdateBufferBinding(context, &mBoundBuffers[target], buffer, target);
Xinghua Cao10a4d432017-11-28 14:46:26 +08001383 mDirtyBits.set(DIRTY_BIT_SHADER_STORAGE_BUFFER_BINDING);
1384 break;
Corentin Wallez336129f2017-10-17 15:55:40 -04001385 default:
James Darpiniane8a93c62018-01-04 18:02:24 -08001386 UpdateBufferBinding(context, &mBoundBuffers[target], buffer, target);
Corentin Wallez336129f2017-10-17 15:55:40 -04001387 break;
1388 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001389}
James Darpiniane8a93c62018-01-04 18:02:24 -08001390
Corentin Wallez336129f2017-10-17 15:55:40 -04001391void State::setIndexedBufferBinding(const Context *context,
1392 BufferBinding target,
1393 GLuint index,
1394 Buffer *buffer,
1395 GLintptr offset,
1396 GLsizeiptr size)
Jiajia Qin9d7d0b12016-11-29 16:30:31 +08001397{
Corentin Wallez336129f2017-10-17 15:55:40 -04001398 setBufferBinding(context, target, buffer);
Jiajia Qin9d7d0b12016-11-29 16:30:31 +08001399
Corentin Wallez336129f2017-10-17 15:55:40 -04001400 switch (target)
1401 {
1402 case BufferBinding::TransformFeedback:
1403 mTransformFeedback->bindIndexedBuffer(context, index, buffer, offset, size);
James Darpiniane8a93c62018-01-04 18:02:24 -08001404 setBufferBinding(context, target, buffer);
Corentin Wallez336129f2017-10-17 15:55:40 -04001405 break;
1406 case BufferBinding::Uniform:
James Darpiniane8a93c62018-01-04 18:02:24 -08001407 UpdateBufferBinding(context, &mUniformBuffers[index], buffer, target, offset, size);
Jamie Madillf4141212017-12-12 15:08:07 -05001408 mDirtyBits.set(DIRTY_BIT_UNIFORM_BUFFER_BINDINGS);
Corentin Wallez336129f2017-10-17 15:55:40 -04001409 break;
1410 case BufferBinding::AtomicCounter:
James Darpiniane8a93c62018-01-04 18:02:24 -08001411 UpdateBufferBinding(context, &mAtomicCounterBuffers[index], buffer, target, offset,
1412 size);
Corentin Wallez336129f2017-10-17 15:55:40 -04001413 break;
1414 case BufferBinding::ShaderStorage:
James Darpiniane8a93c62018-01-04 18:02:24 -08001415 UpdateBufferBinding(context, &mShaderStorageBuffers[index], buffer, target, offset,
1416 size);
Corentin Wallez336129f2017-10-17 15:55:40 -04001417 break;
1418 default:
1419 UNREACHABLE();
1420 break;
1421 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001422}
1423
Geoff Lang5d124a62015-09-15 13:03:27 -04001424const OffsetBindingPointer<Buffer> &State::getIndexedUniformBuffer(size_t index) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001425{
Shannon Woodsf3acaf92014-09-23 18:07:11 -04001426 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
Geoff Lang5d124a62015-09-15 13:03:27 -04001427 return mUniformBuffers[index];
Gregoire Payen de La Garanderie68694e92015-03-24 14:03:37 +00001428}
1429
Jiajia Qin6eafb042016-12-27 17:04:07 +08001430const OffsetBindingPointer<Buffer> &State::getIndexedAtomicCounterBuffer(size_t index) const
1431{
1432 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
1433 return mAtomicCounterBuffers[index];
1434}
1435
Jiajia Qinf546e7d2017-03-27 14:12:59 +08001436const OffsetBindingPointer<Buffer> &State::getIndexedShaderStorageBuffer(size_t index) const
1437{
1438 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
1439 return mShaderStorageBuffers[index];
1440}
1441
Corentin Wallez336129f2017-10-17 15:55:40 -04001442Buffer *State::getTargetBuffer(BufferBinding target) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001443{
1444 switch (target)
1445 {
Corentin Wallez336129f2017-10-17 15:55:40 -04001446 case BufferBinding::ElementArray:
1447 return getVertexArray()->getElementArrayBuffer().get();
Corentin Wallez336129f2017-10-17 15:55:40 -04001448 default:
1449 return mBoundBuffers[target].get();
Shannon Woods53a94a82014-06-24 15:20:36 -04001450 }
1451}
1452
James Darpinian4d9d4832018-03-13 12:43:28 -07001453void State::detachBuffer(const Context *context, const Buffer *buffer)
Yuly Novikov5807a532015-12-03 13:01:22 -05001454{
James Darpinian4d9d4832018-03-13 12:43:28 -07001455 if (!buffer->isBound())
1456 {
1457 return;
1458 }
1459 GLuint bufferName = buffer->id();
James Darpiniane8a93c62018-01-04 18:02:24 -08001460 for (auto target : angle::AllEnums<BufferBinding>())
Yuly Novikov5807a532015-12-03 13:01:22 -05001461 {
James Darpiniane8a93c62018-01-04 18:02:24 -08001462 if (mBoundBuffers[target].id() == bufferName)
Yuly Novikov5807a532015-12-03 13:01:22 -05001463 {
James Darpiniane8a93c62018-01-04 18:02:24 -08001464 UpdateBufferBinding(context, &mBoundBuffers[target], nullptr, target);
Yuly Novikov5807a532015-12-03 13:01:22 -05001465 }
1466 }
1467
1468 TransformFeedback *curTransformFeedback = getCurrentTransformFeedback();
1469 if (curTransformFeedback)
1470 {
Jamie Madill4928b7c2017-06-20 12:57:39 -04001471 curTransformFeedback->detachBuffer(context, bufferName);
Yuly Novikov5807a532015-12-03 13:01:22 -05001472 }
1473
Jamie Madill4928b7c2017-06-20 12:57:39 -04001474 getVertexArray()->detachBuffer(context, bufferName);
James Darpiniane8a93c62018-01-04 18:02:24 -08001475
1476 for (auto &buf : mUniformBuffers)
1477 {
1478 if (buf.id() == bufferName)
1479 {
1480 UpdateBufferBinding(context, &buf, nullptr, BufferBinding::Uniform);
1481 }
1482 }
1483
1484 for (auto &buf : mAtomicCounterBuffers)
1485 {
1486 if (buf.id() == bufferName)
1487 {
1488 UpdateBufferBinding(context, &buf, nullptr, BufferBinding::AtomicCounter);
1489 }
1490 }
1491
1492 for (auto &buf : mShaderStorageBuffers)
1493 {
1494 if (buf.id() == bufferName)
1495 {
1496 UpdateBufferBinding(context, &buf, nullptr, BufferBinding::ShaderStorage);
1497 }
1498 }
Yuly Novikov5807a532015-12-03 13:01:22 -05001499}
1500
Shannon Woods53a94a82014-06-24 15:20:36 -04001501void State::setEnableVertexAttribArray(unsigned int attribNum, bool enabled)
1502{
1503 getVertexArray()->enableAttribute(attribNum, enabled);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001504 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001505}
1506
1507void State::setVertexAttribf(GLuint index, const GLfloat values[4])
1508{
Shannon Woods23e05002014-09-22 19:07:27 -04001509 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001510 mVertexAttribCurrentValues[index].setFloatValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001511 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1512 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001513 mCurrentValuesTypeMask.setIndex(GL_FLOAT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001514}
1515
1516void State::setVertexAttribu(GLuint index, const GLuint values[4])
1517{
Shannon Woods23e05002014-09-22 19:07:27 -04001518 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001519 mVertexAttribCurrentValues[index].setUnsignedIntValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001520 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1521 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001522 mCurrentValuesTypeMask.setIndex(GL_UNSIGNED_INT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001523}
1524
1525void State::setVertexAttribi(GLuint index, const GLint values[4])
1526{
Shannon Woods23e05002014-09-22 19:07:27 -04001527 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001528 mVertexAttribCurrentValues[index].setIntValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001529 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1530 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001531 mCurrentValuesTypeMask.setIndex(GL_INT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001532}
1533
Shaodde78e82017-05-22 14:13:27 +08001534void State::setVertexAttribPointer(const Context *context,
1535 unsigned int attribNum,
1536 Buffer *boundBuffer,
1537 GLint size,
1538 GLenum type,
1539 bool normalized,
1540 bool pureInteger,
1541 GLsizei stride,
1542 const void *pointer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001543{
Shaodde78e82017-05-22 14:13:27 +08001544 getVertexArray()->setVertexAttribPointer(context, attribNum, boundBuffer, size, type,
1545 normalized, pureInteger, stride, pointer);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001546 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Jamie Madill0b9e9032015-08-17 11:51:52 +00001547}
1548
Shaodde78e82017-05-22 14:13:27 +08001549void State::setVertexAttribDivisor(const Context *context, GLuint index, GLuint divisor)
Jamie Madill0b9e9032015-08-17 11:51:52 +00001550{
Shaodde78e82017-05-22 14:13:27 +08001551 getVertexArray()->setVertexAttribDivisor(context, index, divisor);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001552 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001553}
1554
Jamie Madill6de51852017-04-12 09:53:01 -04001555const VertexAttribCurrentValueData &State::getVertexAttribCurrentValue(size_t attribNum) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001556{
Jamie Madill6de51852017-04-12 09:53:01 -04001557 ASSERT(attribNum < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001558 return mVertexAttribCurrentValues[attribNum];
1559}
1560
Jamie Madillcac94a92017-11-10 10:09:32 -05001561const std::vector<VertexAttribCurrentValueData> &State::getVertexAttribCurrentValues() const
1562{
1563 return mVertexAttribCurrentValues;
1564}
1565
Shannon Woods53a94a82014-06-24 15:20:36 -04001566const void *State::getVertexAttribPointer(unsigned int attribNum) const
1567{
1568 return getVertexArray()->getVertexAttribute(attribNum).pointer;
1569}
1570
1571void State::setPackAlignment(GLint alignment)
1572{
1573 mPack.alignment = alignment;
Jamie Madillc67323a2017-11-02 23:11:41 -04001574 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001575}
1576
1577GLint State::getPackAlignment() const
1578{
1579 return mPack.alignment;
1580}
1581
1582void State::setPackReverseRowOrder(bool reverseRowOrder)
1583{
1584 mPack.reverseRowOrder = reverseRowOrder;
Jamie Madillc67323a2017-11-02 23:11:41 -04001585 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001586}
1587
1588bool State::getPackReverseRowOrder() const
1589{
1590 return mPack.reverseRowOrder;
1591}
1592
Minmin Gongadff67b2015-10-14 10:34:45 -04001593void State::setPackRowLength(GLint rowLength)
1594{
1595 mPack.rowLength = rowLength;
Jamie Madillc67323a2017-11-02 23:11:41 -04001596 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001597}
1598
1599GLint State::getPackRowLength() const
1600{
1601 return mPack.rowLength;
1602}
1603
1604void State::setPackSkipRows(GLint skipRows)
1605{
1606 mPack.skipRows = skipRows;
Jamie Madillc67323a2017-11-02 23:11:41 -04001607 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001608}
1609
1610GLint State::getPackSkipRows() const
1611{
1612 return mPack.skipRows;
1613}
1614
1615void State::setPackSkipPixels(GLint skipPixels)
1616{
1617 mPack.skipPixels = skipPixels;
Jamie Madillc67323a2017-11-02 23:11:41 -04001618 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001619}
1620
1621GLint State::getPackSkipPixels() const
1622{
1623 return mPack.skipPixels;
1624}
1625
Shannon Woods53a94a82014-06-24 15:20:36 -04001626const PixelPackState &State::getPackState() const
1627{
1628 return mPack;
1629}
1630
Jamie Madill87de3622015-03-16 10:41:44 -04001631PixelPackState &State::getPackState()
1632{
1633 return mPack;
1634}
1635
Shannon Woods53a94a82014-06-24 15:20:36 -04001636void State::setUnpackAlignment(GLint alignment)
1637{
1638 mUnpack.alignment = alignment;
Jamie Madillc67323a2017-11-02 23:11:41 -04001639 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001640}
1641
1642GLint State::getUnpackAlignment() const
1643{
1644 return mUnpack.alignment;
1645}
1646
Minmin Gongb8aee3b2015-01-27 14:42:36 -08001647void State::setUnpackRowLength(GLint rowLength)
1648{
1649 mUnpack.rowLength = rowLength;
Jamie Madillc67323a2017-11-02 23:11:41 -04001650 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongb8aee3b2015-01-27 14:42:36 -08001651}
1652
1653GLint State::getUnpackRowLength() const
1654{
1655 return mUnpack.rowLength;
1656}
1657
Minmin Gongadff67b2015-10-14 10:34:45 -04001658void State::setUnpackImageHeight(GLint imageHeight)
1659{
1660 mUnpack.imageHeight = imageHeight;
Jamie Madillc67323a2017-11-02 23:11:41 -04001661 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001662}
1663
1664GLint State::getUnpackImageHeight() const
1665{
1666 return mUnpack.imageHeight;
1667}
1668
1669void State::setUnpackSkipImages(GLint skipImages)
1670{
1671 mUnpack.skipImages = skipImages;
Jamie Madillc67323a2017-11-02 23:11:41 -04001672 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001673}
1674
1675GLint State::getUnpackSkipImages() const
1676{
1677 return mUnpack.skipImages;
1678}
1679
1680void State::setUnpackSkipRows(GLint skipRows)
1681{
1682 mUnpack.skipRows = skipRows;
Jamie Madillc67323a2017-11-02 23:11:41 -04001683 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001684}
1685
1686GLint State::getUnpackSkipRows() const
1687{
1688 return mUnpack.skipRows;
1689}
1690
1691void State::setUnpackSkipPixels(GLint skipPixels)
1692{
1693 mUnpack.skipPixels = skipPixels;
Jamie Madillc67323a2017-11-02 23:11:41 -04001694 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001695}
1696
1697GLint State::getUnpackSkipPixels() const
1698{
1699 return mUnpack.skipPixels;
1700}
1701
Shannon Woods53a94a82014-06-24 15:20:36 -04001702const PixelUnpackState &State::getUnpackState() const
1703{
1704 return mUnpack;
1705}
1706
Jamie Madill67102f02015-03-16 10:41:42 -04001707PixelUnpackState &State::getUnpackState()
1708{
1709 return mUnpack;
1710}
1711
Geoff Lang70d0f492015-12-10 17:45:46 -05001712const Debug &State::getDebug() const
1713{
1714 return mDebug;
1715}
1716
1717Debug &State::getDebug()
1718{
1719 return mDebug;
1720}
1721
Sami Väisänena797e062016-05-12 15:23:40 +03001722void State::setCoverageModulation(GLenum components)
1723{
1724 mCoverageModulation = components;
1725 mDirtyBits.set(DIRTY_BIT_COVERAGE_MODULATION);
1726}
1727
1728GLenum State::getCoverageModulation() const
1729{
1730 return mCoverageModulation;
1731}
1732
Sami Väisänene45e53b2016-05-25 10:36:04 +03001733void State::loadPathRenderingMatrix(GLenum matrixMode, const GLfloat *matrix)
1734{
1735 if (matrixMode == GL_PATH_MODELVIEW_CHROMIUM)
1736 {
1737 memcpy(mPathMatrixMV, matrix, 16 * sizeof(GLfloat));
1738 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING_MATRIX_MV);
1739 }
1740 else if (matrixMode == GL_PATH_PROJECTION_CHROMIUM)
1741 {
1742 memcpy(mPathMatrixProj, matrix, 16 * sizeof(GLfloat));
1743 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING_MATRIX_PROJ);
1744 }
1745 else
1746 {
1747 UNREACHABLE();
1748 }
1749}
1750
1751const GLfloat *State::getPathRenderingMatrix(GLenum which) const
1752{
1753 if (which == GL_PATH_MODELVIEW_MATRIX_CHROMIUM)
1754 {
1755 return mPathMatrixMV;
1756 }
1757 else if (which == GL_PATH_PROJECTION_MATRIX_CHROMIUM)
1758 {
1759 return mPathMatrixProj;
1760 }
1761
1762 UNREACHABLE();
1763 return nullptr;
1764}
1765
1766void State::setPathStencilFunc(GLenum func, GLint ref, GLuint mask)
1767{
1768 mPathStencilFunc = func;
1769 mPathStencilRef = ref;
1770 mPathStencilMask = mask;
1771 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING_STENCIL_STATE);
1772}
1773
1774GLenum State::getPathStencilFunc() const
1775{
1776 return mPathStencilFunc;
1777}
1778
1779GLint State::getPathStencilRef() const
1780{
1781 return mPathStencilRef;
1782}
1783
1784GLuint State::getPathStencilMask() const
1785{
1786 return mPathStencilMask;
1787}
1788
Geoff Lang1d2c41d2016-10-19 16:14:46 -07001789void State::setFramebufferSRGB(bool sRGB)
1790{
1791 mFramebufferSRGB = sRGB;
1792 mDirtyBits.set(DIRTY_BIT_FRAMEBUFFER_SRGB);
1793}
1794
1795bool State::getFramebufferSRGB() const
1796{
1797 return mFramebufferSRGB;
1798}
1799
Shannon Woods53a94a82014-06-24 15:20:36 -04001800void State::getBooleanv(GLenum pname, GLboolean *params)
1801{
1802 switch (pname)
1803 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001804 case GL_SAMPLE_COVERAGE_INVERT:
1805 *params = mSampleCoverageInvert;
1806 break;
1807 case GL_DEPTH_WRITEMASK:
1808 *params = mDepthStencil.depthMask;
1809 break;
1810 case GL_COLOR_WRITEMASK:
1811 params[0] = mBlend.colorMaskRed;
1812 params[1] = mBlend.colorMaskGreen;
1813 params[2] = mBlend.colorMaskBlue;
1814 params[3] = mBlend.colorMaskAlpha;
1815 break;
1816 case GL_CULL_FACE:
1817 *params = mRasterizer.cullFace;
1818 break;
1819 case GL_POLYGON_OFFSET_FILL:
1820 *params = mRasterizer.polygonOffsetFill;
1821 break;
1822 case GL_SAMPLE_ALPHA_TO_COVERAGE:
1823 *params = mBlend.sampleAlphaToCoverage;
1824 break;
1825 case GL_SAMPLE_COVERAGE:
1826 *params = mSampleCoverage;
1827 break;
1828 case GL_SAMPLE_MASK:
1829 *params = mSampleMask;
1830 break;
1831 case GL_SCISSOR_TEST:
1832 *params = mScissorTest;
1833 break;
1834 case GL_STENCIL_TEST:
1835 *params = mDepthStencil.stencilTest;
1836 break;
1837 case GL_DEPTH_TEST:
1838 *params = mDepthStencil.depthTest;
1839 break;
1840 case GL_BLEND:
1841 *params = mBlend.blend;
1842 break;
1843 case GL_DITHER:
1844 *params = mBlend.dither;
1845 break;
1846 case GL_TRANSFORM_FEEDBACK_ACTIVE:
1847 *params = getCurrentTransformFeedback()->isActive() ? GL_TRUE : GL_FALSE;
1848 break;
1849 case GL_TRANSFORM_FEEDBACK_PAUSED:
1850 *params = getCurrentTransformFeedback()->isPaused() ? GL_TRUE : GL_FALSE;
1851 break;
1852 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
1853 *params = mPrimitiveRestart;
1854 break;
1855 case GL_RASTERIZER_DISCARD:
1856 *params = isRasterizerDiscardEnabled() ? GL_TRUE : GL_FALSE;
1857 break;
1858 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
1859 *params = mDebug.isOutputSynchronous() ? GL_TRUE : GL_FALSE;
1860 break;
1861 case GL_DEBUG_OUTPUT:
1862 *params = mDebug.isOutputEnabled() ? GL_TRUE : GL_FALSE;
1863 break;
1864 case GL_MULTISAMPLE_EXT:
1865 *params = mMultiSampling;
1866 break;
1867 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
1868 *params = mSampleAlphaToOne;
1869 break;
1870 case GL_BIND_GENERATES_RESOURCE_CHROMIUM:
1871 *params = isBindGeneratesResourceEnabled() ? GL_TRUE : GL_FALSE;
1872 break;
1873 case GL_CLIENT_ARRAYS_ANGLE:
1874 *params = areClientArraysEnabled() ? GL_TRUE : GL_FALSE;
1875 break;
1876 case GL_FRAMEBUFFER_SRGB_EXT:
1877 *params = getFramebufferSRGB() ? GL_TRUE : GL_FALSE;
1878 break;
1879 case GL_ROBUST_RESOURCE_INITIALIZATION_ANGLE:
1880 *params = mRobustResourceInit ? GL_TRUE : GL_FALSE;
1881 break;
1882 case GL_PROGRAM_CACHE_ENABLED_ANGLE:
1883 *params = mProgramBinaryCacheEnabled ? GL_TRUE : GL_FALSE;
1884 break;
Jamie Madillc43be722017-07-13 16:22:14 -04001885
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001886 default:
1887 UNREACHABLE();
1888 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04001889 }
1890}
1891
1892void State::getFloatv(GLenum pname, GLfloat *params)
1893{
1894 // Please note: DEPTH_CLEAR_VALUE is included in our internal getFloatv implementation
1895 // because it is stored as a float, despite the fact that the GL ES 2.0 spec names
1896 // GetIntegerv as its native query function. As it would require conversion in any
1897 // case, this should make no difference to the calling application.
1898 switch (pname)
1899 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001900 case GL_LINE_WIDTH:
1901 *params = mLineWidth;
1902 break;
1903 case GL_SAMPLE_COVERAGE_VALUE:
1904 *params = mSampleCoverageValue;
1905 break;
1906 case GL_DEPTH_CLEAR_VALUE:
1907 *params = mDepthClearValue;
1908 break;
1909 case GL_POLYGON_OFFSET_FACTOR:
1910 *params = mRasterizer.polygonOffsetFactor;
1911 break;
1912 case GL_POLYGON_OFFSET_UNITS:
1913 *params = mRasterizer.polygonOffsetUnits;
1914 break;
1915 case GL_DEPTH_RANGE:
1916 params[0] = mNearZ;
1917 params[1] = mFarZ;
1918 break;
1919 case GL_COLOR_CLEAR_VALUE:
1920 params[0] = mColorClearValue.red;
1921 params[1] = mColorClearValue.green;
1922 params[2] = mColorClearValue.blue;
1923 params[3] = mColorClearValue.alpha;
1924 break;
1925 case GL_BLEND_COLOR:
1926 params[0] = mBlendColor.red;
1927 params[1] = mBlendColor.green;
1928 params[2] = mBlendColor.blue;
1929 params[3] = mBlendColor.alpha;
1930 break;
1931 case GL_MULTISAMPLE_EXT:
1932 *params = static_cast<GLfloat>(mMultiSampling);
1933 break;
1934 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
1935 *params = static_cast<GLfloat>(mSampleAlphaToOne);
1936 break;
1937 case GL_COVERAGE_MODULATION_CHROMIUM:
1938 params[0] = static_cast<GLfloat>(mCoverageModulation);
1939 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -07001940 case GL_ALPHA_TEST_REF:
1941 *params = mGLES1State.mAlphaTestRef;
1942 break;
Lingfeng Yanga43994c2018-03-29 07:21:41 -07001943 case GL_CURRENT_COLOR:
1944 {
1945 const auto &color = mGLES1State.mCurrentColor;
1946 params[0] = color.red;
1947 params[1] = color.green;
1948 params[2] = color.blue;
1949 params[3] = color.alpha;
1950 break;
1951 }
Lingfeng Yang5a7e61b2018-03-29 16:50:32 -07001952 case GL_CURRENT_NORMAL:
1953 {
1954 const auto &normal = mGLES1State.mCurrentNormal;
1955 params[0] = normal[0];
1956 params[1] = normal[1];
1957 params[2] = normal[2];
1958 break;
1959 }
Lingfeng Yang038dd532018-03-29 17:31:52 -07001960 case GL_CURRENT_TEXTURE_COORDS:
1961 {
1962 const auto &texcoord = mGLES1State.mCurrentTextureCoords[mActiveSampler];
1963 params[0] = texcoord.s;
1964 params[1] = texcoord.t;
1965 params[2] = texcoord.r;
1966 params[3] = texcoord.q;
1967 break;
1968 }
Lingfeng Yang3a41af62018-04-09 07:28:56 -07001969 case GL_MODELVIEW_MATRIX:
1970 memcpy(params, mGLES1State.mModelviewMatrices.back().data(), 16 * sizeof(GLfloat));
1971 break;
1972 case GL_PROJECTION_MATRIX:
1973 memcpy(params, mGLES1State.mProjectionMatrices.back().data(), 16 * sizeof(GLfloat));
1974 break;
1975 case GL_TEXTURE_MATRIX:
1976 memcpy(params, mGLES1State.mTextureMatrices[mActiveSampler].back().data(),
1977 16 * sizeof(GLfloat));
1978 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001979 default:
1980 UNREACHABLE();
1981 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04001982 }
1983}
1984
Jamie Madille98b1b52018-03-08 09:47:23 -05001985Error State::getIntegerv(const Context *context, GLenum pname, GLint *params)
Shannon Woods53a94a82014-06-24 15:20:36 -04001986{
1987 if (pname >= GL_DRAW_BUFFER0_EXT && pname <= GL_DRAW_BUFFER15_EXT)
1988 {
1989 unsigned int colorAttachment = (pname - GL_DRAW_BUFFER0_EXT);
Shannon Woods2df6a602014-09-26 16:12:07 -04001990 ASSERT(colorAttachment < mMaxDrawBuffers);
Shannon Woods53a94a82014-06-24 15:20:36 -04001991 Framebuffer *framebuffer = mDrawFramebuffer;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001992 *params = framebuffer->getDrawBufferState(colorAttachment);
Jamie Madille98b1b52018-03-08 09:47:23 -05001993 return NoError();
Shannon Woods53a94a82014-06-24 15:20:36 -04001994 }
1995
1996 // Please note: DEPTH_CLEAR_VALUE is not included in our internal getIntegerv implementation
1997 // because it is stored as a float, despite the fact that the GL ES 2.0 spec names
1998 // GetIntegerv as its native query function. As it would require conversion in any
1999 // case, this should make no difference to the calling application. You may find it in
2000 // State::getFloatv.
2001 switch (pname)
2002 {
Corentin Wallez336129f2017-10-17 15:55:40 -04002003 case GL_ARRAY_BUFFER_BINDING:
2004 *params = mBoundBuffers[BufferBinding::Array].id();
2005 break;
2006 case GL_DRAW_INDIRECT_BUFFER_BINDING:
2007 *params = mBoundBuffers[BufferBinding::DrawIndirect].id();
2008 break;
2009 case GL_ELEMENT_ARRAY_BUFFER_BINDING:
2010 *params = getVertexArray()->getElementArrayBuffer().id();
2011 break;
Jamie Madill690c8eb2018-03-12 15:20:03 -04002012 case GL_DRAW_FRAMEBUFFER_BINDING:
2013 static_assert(GL_DRAW_FRAMEBUFFER_BINDING == GL_DRAW_FRAMEBUFFER_BINDING_ANGLE,
2014 "Enum mismatch");
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002015 *params = mDrawFramebuffer->id();
2016 break;
Jamie Madill690c8eb2018-03-12 15:20:03 -04002017 case GL_READ_FRAMEBUFFER_BINDING:
2018 static_assert(GL_READ_FRAMEBUFFER_BINDING == GL_READ_FRAMEBUFFER_BINDING_ANGLE,
2019 "Enum mismatch");
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002020 *params = mReadFramebuffer->id();
2021 break;
2022 case GL_RENDERBUFFER_BINDING:
2023 *params = mRenderbuffer.id();
2024 break;
2025 case GL_VERTEX_ARRAY_BINDING:
2026 *params = mVertexArray->id();
2027 break;
2028 case GL_CURRENT_PROGRAM:
2029 *params = mProgram ? mProgram->id() : 0;
2030 break;
2031 case GL_PACK_ALIGNMENT:
2032 *params = mPack.alignment;
2033 break;
2034 case GL_PACK_REVERSE_ROW_ORDER_ANGLE:
2035 *params = mPack.reverseRowOrder;
2036 break;
2037 case GL_PACK_ROW_LENGTH:
2038 *params = mPack.rowLength;
2039 break;
2040 case GL_PACK_SKIP_ROWS:
2041 *params = mPack.skipRows;
2042 break;
2043 case GL_PACK_SKIP_PIXELS:
2044 *params = mPack.skipPixels;
2045 break;
2046 case GL_UNPACK_ALIGNMENT:
2047 *params = mUnpack.alignment;
2048 break;
2049 case GL_UNPACK_ROW_LENGTH:
2050 *params = mUnpack.rowLength;
2051 break;
2052 case GL_UNPACK_IMAGE_HEIGHT:
2053 *params = mUnpack.imageHeight;
2054 break;
2055 case GL_UNPACK_SKIP_IMAGES:
2056 *params = mUnpack.skipImages;
2057 break;
2058 case GL_UNPACK_SKIP_ROWS:
2059 *params = mUnpack.skipRows;
2060 break;
2061 case GL_UNPACK_SKIP_PIXELS:
2062 *params = mUnpack.skipPixels;
2063 break;
2064 case GL_GENERATE_MIPMAP_HINT:
2065 *params = mGenerateMipmapHint;
2066 break;
2067 case GL_FRAGMENT_SHADER_DERIVATIVE_HINT_OES:
2068 *params = mFragmentShaderDerivativeHint;
2069 break;
2070 case GL_ACTIVE_TEXTURE:
2071 *params = (static_cast<GLint>(mActiveSampler) + GL_TEXTURE0);
2072 break;
2073 case GL_STENCIL_FUNC:
2074 *params = mDepthStencil.stencilFunc;
2075 break;
2076 case GL_STENCIL_REF:
2077 *params = mStencilRef;
2078 break;
2079 case GL_STENCIL_VALUE_MASK:
2080 *params = CastMaskValue(context, mDepthStencil.stencilMask);
2081 break;
2082 case GL_STENCIL_BACK_FUNC:
2083 *params = mDepthStencil.stencilBackFunc;
2084 break;
2085 case GL_STENCIL_BACK_REF:
2086 *params = mStencilBackRef;
2087 break;
2088 case GL_STENCIL_BACK_VALUE_MASK:
2089 *params = CastMaskValue(context, mDepthStencil.stencilBackMask);
2090 break;
2091 case GL_STENCIL_FAIL:
2092 *params = mDepthStencil.stencilFail;
2093 break;
2094 case GL_STENCIL_PASS_DEPTH_FAIL:
2095 *params = mDepthStencil.stencilPassDepthFail;
2096 break;
2097 case GL_STENCIL_PASS_DEPTH_PASS:
2098 *params = mDepthStencil.stencilPassDepthPass;
2099 break;
2100 case GL_STENCIL_BACK_FAIL:
2101 *params = mDepthStencil.stencilBackFail;
2102 break;
2103 case GL_STENCIL_BACK_PASS_DEPTH_FAIL:
2104 *params = mDepthStencil.stencilBackPassDepthFail;
2105 break;
2106 case GL_STENCIL_BACK_PASS_DEPTH_PASS:
2107 *params = mDepthStencil.stencilBackPassDepthPass;
2108 break;
2109 case GL_DEPTH_FUNC:
2110 *params = mDepthStencil.depthFunc;
2111 break;
2112 case GL_BLEND_SRC_RGB:
2113 *params = mBlend.sourceBlendRGB;
2114 break;
2115 case GL_BLEND_SRC_ALPHA:
2116 *params = mBlend.sourceBlendAlpha;
2117 break;
2118 case GL_BLEND_DST_RGB:
2119 *params = mBlend.destBlendRGB;
2120 break;
2121 case GL_BLEND_DST_ALPHA:
2122 *params = mBlend.destBlendAlpha;
2123 break;
2124 case GL_BLEND_EQUATION_RGB:
2125 *params = mBlend.blendEquationRGB;
2126 break;
2127 case GL_BLEND_EQUATION_ALPHA:
2128 *params = mBlend.blendEquationAlpha;
2129 break;
2130 case GL_STENCIL_WRITEMASK:
2131 *params = CastMaskValue(context, mDepthStencil.stencilWritemask);
2132 break;
2133 case GL_STENCIL_BACK_WRITEMASK:
2134 *params = CastMaskValue(context, mDepthStencil.stencilBackWritemask);
2135 break;
2136 case GL_STENCIL_CLEAR_VALUE:
2137 *params = mStencilClearValue;
2138 break;
2139 case GL_IMPLEMENTATION_COLOR_READ_TYPE:
Jamie Madill690c8eb2018-03-12 15:20:03 -04002140 ANGLE_TRY(mReadFramebuffer->getImplementationColorReadType(
2141 context, reinterpret_cast<GLenum *>(params)));
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002142 break;
2143 case GL_IMPLEMENTATION_COLOR_READ_FORMAT:
Jamie Madill690c8eb2018-03-12 15:20:03 -04002144 ANGLE_TRY(mReadFramebuffer->getImplementationColorReadFormat(
2145 context, reinterpret_cast<GLenum *>(params)));
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002146 break;
2147 case GL_SAMPLE_BUFFERS:
2148 case GL_SAMPLES:
Shannon Woods53a94a82014-06-24 15:20:36 -04002149 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002150 Framebuffer *framebuffer = mDrawFramebuffer;
Jamie Madille98b1b52018-03-08 09:47:23 -05002151 bool complete = false;
2152 ANGLE_TRY(framebuffer->isComplete(context, &complete));
2153 if (complete)
Shannon Woods53a94a82014-06-24 15:20:36 -04002154 {
Jamie Madille98b1b52018-03-08 09:47:23 -05002155 GLint samples = 0;
2156 ANGLE_TRY(framebuffer->getSamples(context, &samples));
Shannon Woods53a94a82014-06-24 15:20:36 -04002157 switch (pname)
2158 {
Jamie Madilla0016b72017-07-14 14:30:46 -04002159 case GL_SAMPLE_BUFFERS:
Jamie Madille98b1b52018-03-08 09:47:23 -05002160 if (samples != 0)
Jamie Madilla0016b72017-07-14 14:30:46 -04002161 {
2162 *params = 1;
2163 }
2164 else
2165 {
2166 *params = 0;
2167 }
2168 break;
2169 case GL_SAMPLES:
Jamie Madille98b1b52018-03-08 09:47:23 -05002170 *params = samples;
Jamie Madilla0016b72017-07-14 14:30:46 -04002171 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002172 }
2173 }
2174 else
2175 {
2176 *params = 0;
2177 }
2178 }
2179 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002180 case GL_VIEWPORT:
2181 params[0] = mViewport.x;
2182 params[1] = mViewport.y;
2183 params[2] = mViewport.width;
2184 params[3] = mViewport.height;
2185 break;
2186 case GL_SCISSOR_BOX:
2187 params[0] = mScissor.x;
2188 params[1] = mScissor.y;
2189 params[2] = mScissor.width;
2190 params[3] = mScissor.height;
2191 break;
2192 case GL_CULL_FACE_MODE:
2193 *params = ToGLenum(mRasterizer.cullMode);
2194 break;
2195 case GL_FRONT_FACE:
2196 *params = mRasterizer.frontFace;
2197 break;
2198 case GL_RED_BITS:
2199 case GL_GREEN_BITS:
2200 case GL_BLUE_BITS:
2201 case GL_ALPHA_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002202 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002203 Framebuffer *framebuffer = getDrawFramebuffer();
2204 const FramebufferAttachment *colorbuffer = framebuffer->getFirstColorbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002205
2206 if (colorbuffer)
2207 {
2208 switch (pname)
2209 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002210 case GL_RED_BITS:
2211 *params = colorbuffer->getRedSize();
2212 break;
2213 case GL_GREEN_BITS:
2214 *params = colorbuffer->getGreenSize();
2215 break;
2216 case GL_BLUE_BITS:
2217 *params = colorbuffer->getBlueSize();
2218 break;
2219 case GL_ALPHA_BITS:
2220 *params = colorbuffer->getAlphaSize();
2221 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002222 }
2223 }
2224 else
2225 {
2226 *params = 0;
2227 }
2228 }
2229 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002230 case GL_DEPTH_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002231 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002232 const Framebuffer *framebuffer = getDrawFramebuffer();
2233 const FramebufferAttachment *depthbuffer = framebuffer->getDepthbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002234
2235 if (depthbuffer)
2236 {
2237 *params = depthbuffer->getDepthSize();
2238 }
2239 else
2240 {
2241 *params = 0;
2242 }
2243 }
2244 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002245 case GL_STENCIL_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002246 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002247 const Framebuffer *framebuffer = getDrawFramebuffer();
2248 const FramebufferAttachment *stencilbuffer = framebuffer->getStencilbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002249
2250 if (stencilbuffer)
2251 {
2252 *params = stencilbuffer->getStencilSize();
2253 }
2254 else
2255 {
2256 *params = 0;
2257 }
2258 }
2259 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002260 case GL_TEXTURE_BINDING_2D:
2261 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2262 *params =
2263 getSamplerTextureId(static_cast<unsigned int>(mActiveSampler), TextureType::_2D);
2264 break;
2265 case GL_TEXTURE_BINDING_RECTANGLE_ANGLE:
2266 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2267 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2268 TextureType::Rectangle);
2269 break;
2270 case GL_TEXTURE_BINDING_CUBE_MAP:
2271 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2272 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2273 TextureType::CubeMap);
2274 break;
2275 case GL_TEXTURE_BINDING_3D:
2276 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2277 *params =
2278 getSamplerTextureId(static_cast<unsigned int>(mActiveSampler), TextureType::_3D);
2279 break;
2280 case GL_TEXTURE_BINDING_2D_ARRAY:
2281 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2282 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2283 TextureType::_2DArray);
2284 break;
2285 case GL_TEXTURE_BINDING_2D_MULTISAMPLE:
2286 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2287 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2288 TextureType::_2DMultisample);
2289 break;
2290 case GL_TEXTURE_BINDING_EXTERNAL_OES:
2291 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2292 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2293 TextureType::External);
2294 break;
2295 case GL_UNIFORM_BUFFER_BINDING:
2296 *params = mBoundBuffers[BufferBinding::Uniform].id();
2297 break;
2298 case GL_TRANSFORM_FEEDBACK_BINDING:
2299 *params = mTransformFeedback.id();
2300 break;
2301 case GL_TRANSFORM_FEEDBACK_BUFFER_BINDING:
2302 *params = mBoundBuffers[BufferBinding::TransformFeedback].id();
2303 break;
2304 case GL_COPY_READ_BUFFER_BINDING:
2305 *params = mBoundBuffers[BufferBinding::CopyRead].id();
2306 break;
2307 case GL_COPY_WRITE_BUFFER_BINDING:
2308 *params = mBoundBuffers[BufferBinding::CopyWrite].id();
2309 break;
2310 case GL_PIXEL_PACK_BUFFER_BINDING:
2311 *params = mBoundBuffers[BufferBinding::PixelPack].id();
2312 break;
2313 case GL_PIXEL_UNPACK_BUFFER_BINDING:
2314 *params = mBoundBuffers[BufferBinding::PixelUnpack].id();
2315 break;
2316 case GL_READ_BUFFER:
2317 *params = mReadFramebuffer->getReadBufferState();
2318 break;
2319 case GL_SAMPLER_BINDING:
2320 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2321 *params = getSamplerId(static_cast<GLuint>(mActiveSampler));
2322 break;
2323 case GL_DEBUG_LOGGED_MESSAGES:
2324 *params = static_cast<GLint>(mDebug.getMessageCount());
2325 break;
2326 case GL_DEBUG_NEXT_LOGGED_MESSAGE_LENGTH:
2327 *params = static_cast<GLint>(mDebug.getNextMessageLength());
2328 break;
2329 case GL_DEBUG_GROUP_STACK_DEPTH:
2330 *params = static_cast<GLint>(mDebug.getGroupStackDepth());
2331 break;
2332 case GL_MULTISAMPLE_EXT:
2333 *params = static_cast<GLint>(mMultiSampling);
2334 break;
2335 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
2336 *params = static_cast<GLint>(mSampleAlphaToOne);
2337 break;
2338 case GL_COVERAGE_MODULATION_CHROMIUM:
2339 *params = static_cast<GLint>(mCoverageModulation);
2340 break;
2341 case GL_ATOMIC_COUNTER_BUFFER_BINDING:
2342 *params = mBoundBuffers[BufferBinding::AtomicCounter].id();
2343 break;
2344 case GL_SHADER_STORAGE_BUFFER_BINDING:
2345 *params = mBoundBuffers[BufferBinding::ShaderStorage].id();
2346 break;
2347 case GL_DISPATCH_INDIRECT_BUFFER_BINDING:
2348 *params = mBoundBuffers[BufferBinding::DispatchIndirect].id();
2349 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -07002350 case GL_ALPHA_TEST_FUNC:
2351 *params = ToGLenum(mGLES1State.mAlphaTestFunc);
2352 break;
Lingfeng Yang96310cd2018-03-28 11:56:28 -07002353 case GL_CLIENT_ACTIVE_TEXTURE:
2354 *params = mGLES1State.mClientActiveTexture + GL_TEXTURE0;
2355 break;
Lingfeng Yangd2488ab2018-04-04 09:25:48 -07002356 case GL_MATRIX_MODE:
2357 *params = ToGLenum(mGLES1State.mMatrixMode);
2358 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002359 default:
2360 UNREACHABLE();
2361 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002362 }
Jamie Madille98b1b52018-03-08 09:47:23 -05002363
2364 return NoError();
Shannon Woods53a94a82014-06-24 15:20:36 -04002365}
2366
Geoff Lang70d0f492015-12-10 17:45:46 -05002367void State::getPointerv(GLenum pname, void **params) const
2368{
2369 switch (pname)
2370 {
2371 case GL_DEBUG_CALLBACK_FUNCTION:
2372 *params = reinterpret_cast<void *>(mDebug.getCallback());
2373 break;
2374 case GL_DEBUG_CALLBACK_USER_PARAM:
2375 *params = const_cast<void *>(mDebug.getUserParam());
2376 break;
2377 default:
2378 UNREACHABLE();
2379 break;
2380 }
2381}
2382
Martin Radev66fb8202016-07-28 11:45:20 +03002383void State::getIntegeri_v(GLenum target, GLuint index, GLint *data)
Shannon Woods53a94a82014-06-24 15:20:36 -04002384{
2385 switch (target)
2386 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002387 case GL_TRANSFORM_FEEDBACK_BUFFER_BINDING:
2388 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2389 *data = mTransformFeedback->getIndexedBuffer(index).id();
2390 break;
2391 case GL_UNIFORM_BUFFER_BINDING:
2392 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2393 *data = mUniformBuffers[index].id();
2394 break;
2395 case GL_ATOMIC_COUNTER_BUFFER_BINDING:
2396 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2397 *data = mAtomicCounterBuffers[index].id();
2398 break;
2399 case GL_SHADER_STORAGE_BUFFER_BINDING:
2400 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2401 *data = mShaderStorageBuffers[index].id();
2402 break;
2403 case GL_VERTEX_BINDING_BUFFER:
2404 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2405 *data = mVertexArray->getVertexBinding(index).getBuffer().id();
2406 break;
2407 case GL_VERTEX_BINDING_DIVISOR:
2408 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2409 *data = mVertexArray->getVertexBinding(index).getDivisor();
2410 break;
2411 case GL_VERTEX_BINDING_OFFSET:
2412 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2413 *data = static_cast<GLuint>(mVertexArray->getVertexBinding(index).getOffset());
2414 break;
2415 case GL_VERTEX_BINDING_STRIDE:
2416 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2417 *data = mVertexArray->getVertexBinding(index).getStride();
2418 break;
2419 case GL_SAMPLE_MASK_VALUE:
2420 ASSERT(static_cast<size_t>(index) < mSampleMaskValues.size());
2421 *data = mSampleMaskValues[index];
2422 break;
2423 case GL_IMAGE_BINDING_NAME:
2424 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2425 *data = mImageUnits[index].texture.id();
2426 break;
2427 case GL_IMAGE_BINDING_LEVEL:
2428 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2429 *data = mImageUnits[index].level;
2430 break;
2431 case GL_IMAGE_BINDING_LAYER:
2432 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2433 *data = mImageUnits[index].layer;
2434 break;
2435 case GL_IMAGE_BINDING_ACCESS:
2436 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2437 *data = mImageUnits[index].access;
2438 break;
2439 case GL_IMAGE_BINDING_FORMAT:
2440 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2441 *data = mImageUnits[index].format;
2442 break;
2443 default:
2444 UNREACHABLE();
2445 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002446 }
Shannon Woods53a94a82014-06-24 15:20:36 -04002447}
2448
Martin Radev66fb8202016-07-28 11:45:20 +03002449void State::getInteger64i_v(GLenum target, GLuint index, GLint64 *data)
Shannon Woods53a94a82014-06-24 15:20:36 -04002450{
2451 switch (target)
2452 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002453 case GL_TRANSFORM_FEEDBACK_BUFFER_START:
2454 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2455 *data = mTransformFeedback->getIndexedBuffer(index).getOffset();
2456 break;
2457 case GL_TRANSFORM_FEEDBACK_BUFFER_SIZE:
2458 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2459 *data = mTransformFeedback->getIndexedBuffer(index).getSize();
2460 break;
2461 case GL_UNIFORM_BUFFER_START:
2462 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2463 *data = mUniformBuffers[index].getOffset();
2464 break;
2465 case GL_UNIFORM_BUFFER_SIZE:
2466 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2467 *data = mUniformBuffers[index].getSize();
2468 break;
2469 case GL_ATOMIC_COUNTER_BUFFER_START:
2470 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2471 *data = mAtomicCounterBuffers[index].getOffset();
2472 break;
2473 case GL_ATOMIC_COUNTER_BUFFER_SIZE:
2474 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2475 *data = mAtomicCounterBuffers[index].getSize();
2476 break;
2477 case GL_SHADER_STORAGE_BUFFER_START:
2478 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2479 *data = mShaderStorageBuffers[index].getOffset();
2480 break;
2481 case GL_SHADER_STORAGE_BUFFER_SIZE:
2482 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2483 *data = mShaderStorageBuffers[index].getSize();
2484 break;
2485 default:
2486 UNREACHABLE();
2487 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002488 }
Martin Radev66fb8202016-07-28 11:45:20 +03002489}
Shannon Woods53a94a82014-06-24 15:20:36 -04002490
Martin Radev66fb8202016-07-28 11:45:20 +03002491void State::getBooleani_v(GLenum target, GLuint index, GLboolean *data)
2492{
Xinghua Cao9c8e1a32017-12-06 17:59:58 +08002493 switch (target)
2494 {
2495 case GL_IMAGE_BINDING_LAYERED:
2496 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2497 *data = mImageUnits[index].layered;
2498 break;
2499 default:
2500 UNREACHABLE();
2501 break;
2502 }
Shannon Woods53a94a82014-06-24 15:20:36 -04002503}
2504
Corentin Wallez336129f2017-10-17 15:55:40 -04002505bool State::hasMappedBuffer(BufferBinding target) const
Jamie Madilld9ba4f72014-08-04 10:47:59 -04002506{
Corentin Wallez336129f2017-10-17 15:55:40 -04002507 if (target == BufferBinding::Array)
Jamie Madilld9ba4f72014-08-04 10:47:59 -04002508 {
Jiawei-Shao2597fb62016-12-09 16:38:02 +08002509 const VertexArray *vao = getVertexArray();
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002510 const auto &vertexAttribs = vao->getVertexAttributes();
Jiawei-Shao2597fb62016-12-09 16:38:02 +08002511 const auto &vertexBindings = vao->getVertexBindings();
Jamie Madilld078c682018-01-02 11:50:24 -05002512 for (size_t attribIndex : vao->getEnabledAttributesMask())
Jamie Madilld9ba4f72014-08-04 10:47:59 -04002513 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002514 const VertexAttribute &vertexAttrib = vertexAttribs[attribIndex];
Martin Radevdd5f27e2017-06-07 10:17:09 +03002515 auto *boundBuffer = vertexBindings[vertexAttrib.bindingIndex].getBuffer().get();
Jamie Madilld9ba4f72014-08-04 10:47:59 -04002516 if (vertexAttrib.enabled && boundBuffer && boundBuffer->isMapped())
2517 {
2518 return true;
2519 }
2520 }
2521
2522 return false;
2523 }
2524 else
2525 {
2526 Buffer *buffer = getTargetBuffer(target);
2527 return (buffer && buffer->isMapped());
2528 }
2529}
2530
Jamie Madillbc918e72018-03-08 09:47:21 -05002531Error State::syncDirtyObjects(const Context *context)
Jamie Madillc9d442d2016-01-20 11:17:24 -05002532{
2533 if (!mDirtyObjects.any())
Jamie Madillbc918e72018-03-08 09:47:21 -05002534 return NoError();
Jamie Madillc9d442d2016-01-20 11:17:24 -05002535
Jamie Madillbc918e72018-03-08 09:47:21 -05002536 return syncDirtyObjects(context, mDirtyObjects);
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002537}
2538
Jamie Madillbc918e72018-03-08 09:47:21 -05002539Error State::syncDirtyObjects(const Context *context, const DirtyObjects &bitset)
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002540{
Jiajia Qin5ae6ee42018-03-06 17:39:42 +08002541 const DirtyObjects &dirtyObjects = mDirtyObjects & bitset;
2542 for (auto dirtyObject : dirtyObjects)
Jamie Madillc9d442d2016-01-20 11:17:24 -05002543 {
2544 switch (dirtyObject)
2545 {
2546 case DIRTY_OBJECT_READ_FRAMEBUFFER:
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002547 ASSERT(mReadFramebuffer);
Jamie Madill19fa1c62018-03-08 09:47:21 -05002548 ANGLE_TRY(mReadFramebuffer->syncState(context));
Jamie Madillc9d442d2016-01-20 11:17:24 -05002549 break;
2550 case DIRTY_OBJECT_DRAW_FRAMEBUFFER:
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002551 ASSERT(mDrawFramebuffer);
Jamie Madill19fa1c62018-03-08 09:47:21 -05002552 ANGLE_TRY(mDrawFramebuffer->syncState(context));
Jamie Madillc9d442d2016-01-20 11:17:24 -05002553 break;
2554 case DIRTY_OBJECT_VERTEX_ARRAY:
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002555 ASSERT(mVertexArray);
Frank Henigman0af5b862018-03-27 20:19:33 -04002556 ANGLE_TRY(mVertexArray->syncState(context));
Jamie Madillc9d442d2016-01-20 11:17:24 -05002557 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002558 case DIRTY_OBJECT_PROGRAM_TEXTURES:
2559 syncProgramTextures(context);
2560 break;
2561
Jamie Madillc9d442d2016-01-20 11:17:24 -05002562 default:
2563 UNREACHABLE();
2564 break;
2565 }
2566 }
2567
Jiajia Qin5ae6ee42018-03-06 17:39:42 +08002568 mDirtyObjects &= ~dirtyObjects;
Jamie Madillbc918e72018-03-08 09:47:21 -05002569 return NoError();
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002570}
2571
Jamie Madill81c2e252017-09-09 23:32:46 -04002572void State::syncProgramTextures(const Context *context)
2573{
Jamie Madill81c2e252017-09-09 23:32:46 -04002574 // TODO(jmadill): Fine-grained updates.
2575 if (!mProgram)
2576 {
2577 return;
2578 }
2579
2580 ASSERT(mDirtyObjects[DIRTY_OBJECT_PROGRAM_TEXTURES]);
2581 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
2582
Jamie Madill0f80ed82017-09-19 00:24:56 -04002583 ActiveTextureMask newActiveTextures;
2584
Geoff Lange51ba632017-11-21 11:45:25 -05002585 // Initialize to the 'Initialized' state and set to 'MayNeedInit' if any texture is not
2586 // initialized.
2587 mCachedTexturesInitState = InitState::Initialized;
2588
Jamie Madill81c2e252017-09-09 23:32:46 -04002589 for (const SamplerBinding &samplerBinding : mProgram->getSamplerBindings())
2590 {
2591 if (samplerBinding.unreferenced)
2592 continue;
2593
Corentin Wallezf0e89be2017-11-08 14:00:32 -08002594 TextureType textureType = samplerBinding.textureType;
Jamie Madill81c2e252017-09-09 23:32:46 -04002595 for (GLuint textureUnitIndex : samplerBinding.boundTextureUnits)
2596 {
2597 Texture *texture = getSamplerTexture(textureUnitIndex, textureType);
Jamie Madill06ef36b2017-09-09 23:32:46 -04002598 Sampler *sampler = getSampler(textureUnitIndex);
Jamie Madill0f80ed82017-09-19 00:24:56 -04002599 ASSERT(static_cast<size_t>(textureUnitIndex) < mCompleteTextureCache.size());
2600 ASSERT(static_cast<size_t>(textureUnitIndex) < newActiveTextures.size());
Jamie Madill81c2e252017-09-09 23:32:46 -04002601
Jamie Madill42975642017-10-12 12:31:51 -04002602 ASSERT(texture);
Jamie Madill81c2e252017-09-09 23:32:46 -04002603
Jamie Madill42975642017-10-12 12:31:51 -04002604 // Mark the texture binding bit as dirty if the texture completeness changes.
2605 // TODO(jmadill): Use specific dirty bit for completeness change.
2606 if (texture->isSamplerComplete(context, sampler) &&
2607 !mDrawFramebuffer->hasTextureAttachment(texture))
2608 {
2609 texture->syncState();
2610 mCompleteTextureCache[textureUnitIndex] = texture;
Jamie Madill81c2e252017-09-09 23:32:46 -04002611 }
Jamie Madill42975642017-10-12 12:31:51 -04002612 else
2613 {
2614 mCompleteTextureCache[textureUnitIndex] = nullptr;
2615 }
2616
2617 // Bind the texture unconditionally, to recieve completeness change notifications.
Jamie Madill888081d2018-02-27 00:24:46 -05002618 mCompleteTextureBindings[textureUnitIndex].bind(texture->getSubject());
Jamie Madilla59fc192017-11-02 12:57:58 -04002619 mActiveTexturesMask.set(textureUnitIndex);
Jamie Madill42975642017-10-12 12:31:51 -04002620 newActiveTextures.set(textureUnitIndex);
Jamie Madill81c2e252017-09-09 23:32:46 -04002621
Jamie Madill06ef36b2017-09-09 23:32:46 -04002622 if (sampler != nullptr)
2623 {
2624 sampler->syncState(context);
2625 }
Geoff Lange51ba632017-11-21 11:45:25 -05002626
2627 if (texture->initState() == InitState::MayNeedInit)
2628 {
2629 mCachedTexturesInitState = InitState::MayNeedInit;
2630 }
Jamie Madill81c2e252017-09-09 23:32:46 -04002631 }
2632 }
Jamie Madill0f80ed82017-09-19 00:24:56 -04002633
2634 // Unset now missing textures.
Jamie Madilla59fc192017-11-02 12:57:58 -04002635 ActiveTextureMask negativeMask = mActiveTexturesMask & ~newActiveTextures;
Jamie Madill0f80ed82017-09-19 00:24:56 -04002636 if (negativeMask.any())
2637 {
2638 for (auto textureIndex : negativeMask)
2639 {
2640 mCompleteTextureBindings[textureIndex].reset();
2641 mCompleteTextureCache[textureIndex] = nullptr;
Jamie Madilla59fc192017-11-02 12:57:58 -04002642 mActiveTexturesMask.reset(textureIndex);
Jamie Madill0f80ed82017-09-19 00:24:56 -04002643 }
2644 }
Jamie Madill81c2e252017-09-09 23:32:46 -04002645}
2646
Jamie Madillbc918e72018-03-08 09:47:21 -05002647Error State::syncDirtyObject(const Context *context, GLenum target)
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002648{
2649 DirtyObjects localSet;
2650
2651 switch (target)
2652 {
2653 case GL_READ_FRAMEBUFFER:
2654 localSet.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2655 break;
2656 case GL_DRAW_FRAMEBUFFER:
2657 localSet.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2658 break;
2659 case GL_FRAMEBUFFER:
2660 localSet.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2661 localSet.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2662 break;
2663 case GL_VERTEX_ARRAY:
2664 localSet.set(DIRTY_OBJECT_VERTEX_ARRAY);
2665 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002666 case GL_TEXTURE:
2667 case GL_SAMPLER:
2668 case GL_PROGRAM:
2669 localSet.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
2670 break;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002671 }
2672
Jamie Madillbc918e72018-03-08 09:47:21 -05002673 return syncDirtyObjects(context, localSet);
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002674}
2675
2676void State::setObjectDirty(GLenum target)
2677{
2678 switch (target)
2679 {
2680 case GL_READ_FRAMEBUFFER:
2681 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2682 break;
2683 case GL_DRAW_FRAMEBUFFER:
2684 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2685 break;
2686 case GL_FRAMEBUFFER:
2687 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2688 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2689 break;
2690 case GL_VERTEX_ARRAY:
2691 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
2692 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002693 case GL_TEXTURE:
2694 case GL_SAMPLER:
Jamie Madill81c2e252017-09-09 23:32:46 -04002695 case GL_PROGRAM:
2696 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
2697 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
2698 break;
Jamie Madilla779b612017-07-24 11:46:05 -04002699 }
2700}
2701
Jamie Madill888081d2018-02-27 00:24:46 -05002702void State::setFramebufferDirty(const Framebuffer *framebuffer) const
2703{
2704 if (framebuffer == mReadFramebuffer)
2705 {
2706 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2707 }
2708 if (framebuffer == mDrawFramebuffer)
2709 {
2710 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2711 }
2712}
2713
Jamie Madill09463932018-04-04 05:26:59 -04002714void State::setVertexArrayDirty(const VertexArray *vertexArray) const
2715{
2716 if (vertexArray == mVertexArray)
2717 {
2718 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
2719 }
2720}
2721
Jamie Madilla779b612017-07-24 11:46:05 -04002722void State::onProgramExecutableChange(Program *program)
2723{
2724 // OpenGL Spec:
2725 // "If LinkProgram or ProgramBinary successfully re-links a program object
2726 // that was already in use as a result of a previous call to UseProgram, then the
2727 // generated executable code will be installed as part of the current rendering state."
2728 if (program->isLinked() && mProgram == program)
2729 {
2730 mDirtyBits.set(DIRTY_BIT_PROGRAM_EXECUTABLE);
Jamie Madill81c2e252017-09-09 23:32:46 -04002731 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002732 }
Shannon Woods53a94a82014-06-24 15:20:36 -04002733}
Jamie Madillc9d442d2016-01-20 11:17:24 -05002734
Xinghua Cao65ec0b22017-03-28 16:10:52 +08002735void State::setImageUnit(const Context *context,
2736 GLuint unit,
2737 Texture *texture,
2738 GLint level,
2739 GLboolean layered,
2740 GLint layer,
2741 GLenum access,
2742 GLenum format)
2743{
2744 mImageUnits[unit].texture.set(context, texture);
2745 mImageUnits[unit].level = level;
2746 mImageUnits[unit].layered = layered;
2747 mImageUnits[unit].layer = layer;
2748 mImageUnits[unit].access = access;
2749 mImageUnits[unit].format = format;
2750}
2751
2752const ImageUnit &State::getImageUnit(GLuint unit) const
2753{
2754 return mImageUnits[unit];
2755}
2756
Jamie Madill81c2e252017-09-09 23:32:46 -04002757// Handle a dirty texture event.
Jamie Madilld4442552018-02-27 22:03:47 -05002758void State::onSubjectStateChange(const Context *context,
2759 angle::SubjectIndex index,
2760 angle::SubjectMessage message)
Jamie Madill81c2e252017-09-09 23:32:46 -04002761{
2762 // Conservatively assume all textures are dirty.
2763 // TODO(jmadill): More fine-grained update.
2764 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Geoff Lange51ba632017-11-21 11:45:25 -05002765
Jamie Madilld4442552018-02-27 22:03:47 -05002766 if (!mCompleteTextureCache[index] ||
2767 mCompleteTextureCache[index]->initState() == InitState::MayNeedInit)
Geoff Lange51ba632017-11-21 11:45:25 -05002768 {
2769 mCachedTexturesInitState = InitState::MayNeedInit;
2770 }
Jamie Madill81c2e252017-09-09 23:32:46 -04002771}
2772
Jamie Madill05b35b22017-10-03 09:01:44 -04002773Error State::clearUnclearedActiveTextures(const Context *context)
2774{
Jamie Madilla59fc192017-11-02 12:57:58 -04002775 ASSERT(mRobustResourceInit);
Jamie Madill05b35b22017-10-03 09:01:44 -04002776
Geoff Lange51ba632017-11-21 11:45:25 -05002777 if (mCachedTexturesInitState == InitState::Initialized)
2778 {
2779 return NoError();
2780 }
2781
Geoff Langd4fff502017-09-22 11:28:28 -04002782 ASSERT(!mDirtyObjects.any());
2783
Jamie Madilla59fc192017-11-02 12:57:58 -04002784 for (auto textureIndex : mActiveTexturesMask)
Jamie Madill05b35b22017-10-03 09:01:44 -04002785 {
Jamie Madilla59fc192017-11-02 12:57:58 -04002786 Texture *texture = mCompleteTextureCache[textureIndex];
Jamie Madill05b35b22017-10-03 09:01:44 -04002787 if (texture)
2788 {
2789 ANGLE_TRY(texture->ensureInitialized(context));
2790 }
2791 }
Jamie Madilla59fc192017-11-02 12:57:58 -04002792
Geoff Lange51ba632017-11-21 11:45:25 -05002793 mCachedTexturesInitState = InitState::Initialized;
2794
Jamie Madill05b35b22017-10-03 09:01:44 -04002795 return NoError();
2796}
2797
Jamie Madillc67323a2017-11-02 23:11:41 -04002798AttributesMask State::getAndResetDirtyCurrentValues() const
2799{
2800 AttributesMask retVal = mDirtyCurrentValues;
2801 mDirtyCurrentValues.reset();
2802 return retVal;
2803}
2804
James Darpiniane8a93c62018-01-04 18:02:24 -08002805bool State::isCurrentTransformFeedback(const TransformFeedback *tf) const
2806{
2807 return tf == mTransformFeedback.get();
2808}
2809bool State::isCurrentVertexArray(const VertexArray *va) const
2810{
2811 return va == mVertexArray;
2812}
2813
Jamie Madillc9d442d2016-01-20 11:17:24 -05002814} // namespace gl