blob: de731caf779c377d2180e1a8449e2a3b5712c103 [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 Yang54ef3ad2018-03-12 08:31:12 -0700101State::~State() {}
Geoff Lang76b10c92014-09-05 16:28:14 -0400102
Jamie Madill4928b7c2017-06-20 12:57:39 -0400103void State::initialize(const Context *context,
Geoff Langf41a7152016-09-19 15:11:17 -0400104 bool debug,
Geoff Langfeb8c682017-02-13 16:07:35 -0500105 bool bindGeneratesResource,
Jamie Madille08a1d32017-03-07 17:24:06 -0500106 bool clientArraysEnabled,
Jamie Madillc43be722017-07-13 16:22:14 -0400107 bool robustResourceInit,
108 bool programBinaryCacheEnabled)
Geoff Lang76b10c92014-09-05 16:28:14 -0400109{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700110 const Caps &caps = context->getCaps();
111 const Extensions &extensions = context->getExtensions();
Geoff Lang4751aab2017-10-30 15:14:52 -0400112 const Extensions &nativeExtensions = context->getImplementation()->getNativeExtensions();
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700113 const Version &clientVersion = context->getClientVersion();
Jamie Madill4928b7c2017-06-20 12:57:39 -0400114
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700115 mMaxDrawBuffers = caps.maxDrawBuffers;
Shannon Woods2df6a602014-09-26 16:12:07 -0400116 mMaxCombinedTextureImageUnits = caps.maxCombinedTextureImageUnits;
Shannon Woods53a94a82014-06-24 15:20:36 -0400117
Jamie Madillf75ab352015-03-16 10:46:52 -0400118 setColorClearValue(0.0f, 0.0f, 0.0f, 0.0f);
Shannon Woods53a94a82014-06-24 15:20:36 -0400119
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700120 mDepthClearValue = 1.0f;
Shannon Woods53a94a82014-06-24 15:20:36 -0400121 mStencilClearValue = 0;
122
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700123 mScissorTest = false;
124 mScissor.x = 0;
125 mScissor.y = 0;
126 mScissor.width = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400127 mScissor.height = 0;
128
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700129 mBlendColor.red = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400130 mBlendColor.green = 0;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700131 mBlendColor.blue = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400132 mBlendColor.alpha = 0;
133
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700134 mStencilRef = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400135 mStencilBackRef = 0;
136
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700137 mSampleCoverage = false;
138 mSampleCoverageValue = 1.0f;
Shannon Woods53a94a82014-06-24 15:20:36 -0400139 mSampleCoverageInvert = false;
Jiawei Shaodb342272017-09-27 10:21:45 +0800140
141 mMaxSampleMaskWords = caps.maxSampleMaskWords;
142 mSampleMask = false;
143 mSampleMaskValues.fill(~GLbitfield(0));
144
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700145 mGenerateMipmapHint = GL_DONT_CARE;
Shannon Woods53a94a82014-06-24 15:20:36 -0400146 mFragmentShaderDerivativeHint = GL_DONT_CARE;
147
Geoff Langf41a7152016-09-19 15:11:17 -0400148 mBindGeneratesResource = bindGeneratesResource;
Geoff Langfeb8c682017-02-13 16:07:35 -0500149 mClientArraysEnabled = clientArraysEnabled;
Geoff Langf41a7152016-09-19 15:11:17 -0400150
Shannon Woods53a94a82014-06-24 15:20:36 -0400151 mLineWidth = 1.0f;
152
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700153 mViewport.x = 0;
154 mViewport.y = 0;
155 mViewport.width = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400156 mViewport.height = 0;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700157 mNearZ = 0.0f;
158 mFarZ = 1.0f;
Shannon Woods53a94a82014-06-24 15:20:36 -0400159
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700160 mBlend.colorMaskRed = true;
Shannon Woods53a94a82014-06-24 15:20:36 -0400161 mBlend.colorMaskGreen = true;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700162 mBlend.colorMaskBlue = true;
Shannon Woods53a94a82014-06-24 15:20:36 -0400163 mBlend.colorMaskAlpha = true;
164
Geoff Lang76b10c92014-09-05 16:28:14 -0400165 mActiveSampler = 0;
166
Shannon Woods23e05002014-09-22 19:07:27 -0400167 mVertexAttribCurrentValues.resize(caps.maxVertexAttributes);
Shannon Woods53a94a82014-06-24 15:20:36 -0400168
Brandon Jonesc405ae72017-12-06 14:15:03 -0800169 // Set all indexes in state attributes type mask to float (default)
170 for (int i = 0; i < MAX_VERTEX_ATTRIBS; i++)
171 {
172 mCurrentValuesTypeMask.setIndex(GL_FLOAT, i);
173 }
174
Geoff Lang4dc3af02016-11-18 14:09:27 -0500175 mUniformBuffers.resize(caps.maxUniformBufferBindings);
Shannon Woodsf3acaf92014-09-23 18:07:11 -0400176
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800177 mSamplerTextures[TextureType::_2D].resize(caps.maxCombinedTextureImageUnits);
178 mSamplerTextures[TextureType::CubeMap].resize(caps.maxCombinedTextureImageUnits);
Geoff Langeb66a6e2016-10-31 13:06:12 -0400179 if (clientVersion >= Version(3, 0))
Shannon Woods53a94a82014-06-24 15:20:36 -0400180 {
Geoff Lang76b10c92014-09-05 16:28:14 -0400181 // TODO: These could also be enabled via extension
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800182 mSamplerTextures[TextureType::_2DArray].resize(caps.maxCombinedTextureImageUnits);
183 mSamplerTextures[TextureType::_3D].resize(caps.maxCombinedTextureImageUnits);
Shannon Woods53a94a82014-06-24 15:20:36 -0400184 }
Geoff Lang3b573612016-10-31 14:08:10 -0400185 if (clientVersion >= Version(3, 1))
186 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800187 mSamplerTextures[TextureType::_2DMultisample].resize(caps.maxCombinedTextureImageUnits);
Jiajia Qin6eafb042016-12-27 17:04:07 +0800188
189 mAtomicCounterBuffers.resize(caps.maxAtomicCounterBufferBindings);
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800190 mShaderStorageBuffers.resize(caps.maxShaderStorageBufferBindings);
Xinghua Cao65ec0b22017-03-28 16:10:52 +0800191 mImageUnits.resize(caps.maxImageUnits);
Geoff Lang3b573612016-10-31 14:08:10 -0400192 }
Geoff Lang4751aab2017-10-30 15:14:52 -0400193 if (nativeExtensions.textureRectangle)
Corentin Wallez13c0dd42017-07-04 18:27:01 -0400194 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800195 mSamplerTextures[TextureType::Rectangle].resize(caps.maxCombinedTextureImageUnits);
Corentin Wallez13c0dd42017-07-04 18:27:01 -0400196 }
Geoff Lang4751aab2017-10-30 15:14:52 -0400197 if (nativeExtensions.eglImageExternal || nativeExtensions.eglStreamConsumerExternal)
Ian Ewellbda75592016-04-18 17:25:54 -0400198 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800199 mSamplerTextures[TextureType::External].resize(caps.maxCombinedTextureImageUnits);
Ian Ewellbda75592016-04-18 17:25:54 -0400200 }
Jamie Madill81c2e252017-09-09 23:32:46 -0400201 mCompleteTextureCache.resize(caps.maxCombinedTextureImageUnits, nullptr);
202 mCompleteTextureBindings.reserve(caps.maxCombinedTextureImageUnits);
Geoff Lange51ba632017-11-21 11:45:25 -0500203 mCachedTexturesInitState = InitState::MayNeedInit;
Jamie Madill81c2e252017-09-09 23:32:46 -0400204 for (uint32_t textureIndex = 0; textureIndex < caps.maxCombinedTextureImageUnits;
205 ++textureIndex)
206 {
Jamie Madilld4442552018-02-27 22:03:47 -0500207 mCompleteTextureBindings.emplace_back(this, textureIndex);
Jamie Madill81c2e252017-09-09 23:32:46 -0400208 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400209
Geoff Lang76b10c92014-09-05 16:28:14 -0400210 mSamplers.resize(caps.maxCombinedTextureImageUnits);
Shannon Woods53a94a82014-06-24 15:20:36 -0400211
Jamie Madill4928b7c2017-06-20 12:57:39 -0400212 mActiveQueries[GL_ANY_SAMPLES_PASSED].set(context, nullptr);
213 mActiveQueries[GL_ANY_SAMPLES_PASSED_CONSERVATIVE].set(context, nullptr);
214 mActiveQueries[GL_TRANSFORM_FEEDBACK_PRIMITIVES_WRITTEN].set(context, nullptr);
215 mActiveQueries[GL_TIME_ELAPSED_EXT].set(context, nullptr);
216 mActiveQueries[GL_COMMANDS_COMPLETED_CHROMIUM].set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400217
Ian Ewell3ffd78b2016-01-22 16:09:42 -0500218 mProgram = nullptr;
Shannon Woods53a94a82014-06-24 15:20:36 -0400219
Ian Ewell3ffd78b2016-01-22 16:09:42 -0500220 mReadFramebuffer = nullptr;
221 mDrawFramebuffer = nullptr;
Jamie Madillb4b53c52015-02-03 15:22:48 -0500222
223 mPrimitiveRestart = false;
Geoff Lang70d0f492015-12-10 17:45:46 -0500224
225 mDebug.setOutputEnabled(debug);
226 mDebug.setMaxLoggedMessages(extensions.maxDebugLoggedMessages);
Sami Väisänen74c23472016-05-09 17:30:30 +0300227
Geoff Lang488130e2017-09-27 13:53:11 -0400228 mMultiSampling = true;
229 mSampleAlphaToOne = false;
Sami Väisänena797e062016-05-12 15:23:40 +0300230
231 mCoverageModulation = GL_NONE;
Sami Väisänene45e53b2016-05-25 10:36:04 +0300232
233 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixProj);
234 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixMV);
235 mPathStencilFunc = GL_ALWAYS;
236 mPathStencilRef = 0;
237 mPathStencilMask = std::numeric_limits<GLuint>::max();
Jamie Madille08a1d32017-03-07 17:24:06 -0500238
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700239 mRobustResourceInit = robustResourceInit;
Jamie Madillc43be722017-07-13 16:22:14 -0400240 mProgramBinaryCacheEnabled = programBinaryCacheEnabled;
Lingfeng Yangdbb9c532018-02-25 19:58:24 -0800241
242 // GLES1 emulation: Initialize state for GLES1 if version
243 // applies
244 if (clientVersion < Version(2, 0))
245 {
246 mGLES1State.initialize(context);
247 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400248}
249
Jamie Madill6c1f6712017-02-14 19:08:04 -0500250void State::reset(const Context *context)
Shannon Woods53a94a82014-06-24 15:20:36 -0400251{
Jamie Madill8693bdb2017-09-02 15:32:14 -0400252 for (auto &bindingVec : mSamplerTextures)
Shannon Woods53a94a82014-06-24 15:20:36 -0400253 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800254 for (size_t textureIdx = 0; textureIdx < bindingVec.size(); textureIdx++)
Shannon Woods53a94a82014-06-24 15:20:36 -0400255 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800256 bindingVec[textureIdx].set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400257 }
258 }
Geoff Lang76b10c92014-09-05 16:28:14 -0400259 for (size_t samplerIdx = 0; samplerIdx < mSamplers.size(); samplerIdx++)
260 {
Jamie Madill4928b7c2017-06-20 12:57:39 -0400261 mSamplers[samplerIdx].set(context, nullptr);
Geoff Lang76b10c92014-09-05 16:28:14 -0400262 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400263
Xinghua Cao65ec0b22017-03-28 16:10:52 +0800264 for (auto &imageUnit : mImageUnits)
265 {
266 imageUnit.texture.set(context, nullptr);
267 imageUnit.level = 0;
268 imageUnit.layered = false;
269 imageUnit.layer = 0;
270 imageUnit.access = GL_READ_ONLY;
271 imageUnit.format = GL_R32UI;
272 }
273
Jamie Madill4928b7c2017-06-20 12:57:39 -0400274 mRenderbuffer.set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400275
Corentin Wallez336129f2017-10-17 15:55:40 -0400276 for (auto type : angle::AllEnums<BufferBinding>())
277 {
James Darpiniane8a93c62018-01-04 18:02:24 -0800278 UpdateBufferBinding(context, &mBoundBuffers[type], nullptr, type);
Corentin Wallez336129f2017-10-17 15:55:40 -0400279 }
280
Geoff Lang7dd2e102014-11-10 15:19:26 -0500281 if (mProgram)
282 {
Jamie Madill6c1f6712017-02-14 19:08:04 -0500283 mProgram->release(context);
Geoff Lang7dd2e102014-11-10 15:19:26 -0500284 }
Yunchao Hed7297bf2017-04-19 15:27:10 +0800285 mProgram = nullptr;
Geoff Lang7dd2e102014-11-10 15:19:26 -0500286
Yunchao Hea336b902017-08-02 16:05:21 +0800287 mProgramPipeline.set(context, nullptr);
288
James Darpiniane8a93c62018-01-04 18:02:24 -0800289 if (mTransformFeedback.get())
290 mTransformFeedback->onBindingChanged(false);
Jamie Madill4928b7c2017-06-20 12:57:39 -0400291 mTransformFeedback.set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400292
293 for (State::ActiveQueryMap::iterator i = mActiveQueries.begin(); i != mActiveQueries.end(); i++)
294 {
Jamie Madill4928b7c2017-06-20 12:57:39 -0400295 i->second.set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400296 }
297
Corentin Wallez336129f2017-10-17 15:55:40 -0400298 for (auto &buf : mUniformBuffers)
Shannon Woods53a94a82014-06-24 15:20:36 -0400299 {
James Darpiniane8a93c62018-01-04 18:02:24 -0800300 UpdateBufferBinding(context, &buf, nullptr, BufferBinding::Uniform);
Shannon Woods53a94a82014-06-24 15:20:36 -0400301 }
302
Jiajia Qin6eafb042016-12-27 17:04:07 +0800303 for (auto &buf : mAtomicCounterBuffers)
304 {
James Darpiniane8a93c62018-01-04 18:02:24 -0800305 UpdateBufferBinding(context, &buf, nullptr, BufferBinding::AtomicCounter);
Jiajia Qin6eafb042016-12-27 17:04:07 +0800306 }
307
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800308 for (auto &buf : mShaderStorageBuffers)
309 {
James Darpiniane8a93c62018-01-04 18:02:24 -0800310 UpdateBufferBinding(context, &buf, nullptr, BufferBinding::ShaderStorage);
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800311 }
312
Sami Väisänene45e53b2016-05-25 10:36:04 +0300313 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixProj);
314 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixMV);
315 mPathStencilFunc = GL_ALWAYS;
316 mPathStencilRef = 0;
317 mPathStencilMask = std::numeric_limits<GLuint>::max();
318
Jamie Madill1b94d432015-08-07 13:23:23 -0400319 // TODO(jmadill): Is this necessary?
320 setAllDirtyBits();
Shannon Woods53a94a82014-06-24 15:20:36 -0400321}
322
323const RasterizerState &State::getRasterizerState() const
324{
325 return mRasterizer;
326}
327
328const BlendState &State::getBlendState() const
329{
330 return mBlend;
331}
332
333const DepthStencilState &State::getDepthStencilState() const
334{
335 return mDepthStencil;
336}
337
Jamie Madillf75ab352015-03-16 10:46:52 -0400338void State::setColorClearValue(float red, float green, float blue, float alpha)
Shannon Woods53a94a82014-06-24 15:20:36 -0400339{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700340 mColorClearValue.red = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400341 mColorClearValue.green = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700342 mColorClearValue.blue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400343 mColorClearValue.alpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400344 mDirtyBits.set(DIRTY_BIT_CLEAR_COLOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400345}
346
Jamie Madillf75ab352015-03-16 10:46:52 -0400347void State::setDepthClearValue(float depth)
Shannon Woods53a94a82014-06-24 15:20:36 -0400348{
349 mDepthClearValue = depth;
Jamie Madill1b94d432015-08-07 13:23:23 -0400350 mDirtyBits.set(DIRTY_BIT_CLEAR_DEPTH);
Shannon Woods53a94a82014-06-24 15:20:36 -0400351}
352
Jamie Madillf75ab352015-03-16 10:46:52 -0400353void State::setStencilClearValue(int stencil)
Shannon Woods53a94a82014-06-24 15:20:36 -0400354{
355 mStencilClearValue = stencil;
Jamie Madill1b94d432015-08-07 13:23:23 -0400356 mDirtyBits.set(DIRTY_BIT_CLEAR_STENCIL);
Shannon Woods53a94a82014-06-24 15:20:36 -0400357}
358
Shannon Woods53a94a82014-06-24 15:20:36 -0400359void State::setColorMask(bool red, bool green, bool blue, bool alpha)
360{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700361 mBlend.colorMaskRed = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400362 mBlend.colorMaskGreen = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700363 mBlend.colorMaskBlue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400364 mBlend.colorMaskAlpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400365 mDirtyBits.set(DIRTY_BIT_COLOR_MASK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400366}
367
368void State::setDepthMask(bool mask)
369{
370 mDepthStencil.depthMask = mask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400371 mDirtyBits.set(DIRTY_BIT_DEPTH_MASK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400372}
373
374bool State::isRasterizerDiscardEnabled() const
375{
376 return mRasterizer.rasterizerDiscard;
377}
378
379void State::setRasterizerDiscard(bool enabled)
380{
381 mRasterizer.rasterizerDiscard = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400382 mDirtyBits.set(DIRTY_BIT_RASTERIZER_DISCARD_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400383}
384
385bool State::isCullFaceEnabled() const
386{
387 return mRasterizer.cullFace;
388}
389
390void State::setCullFace(bool enabled)
391{
392 mRasterizer.cullFace = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400393 mDirtyBits.set(DIRTY_BIT_CULL_FACE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400394}
395
Corentin Wallez2e568cf2017-09-18 17:05:22 -0400396void State::setCullMode(CullFaceMode mode)
Shannon Woods53a94a82014-06-24 15:20:36 -0400397{
398 mRasterizer.cullMode = mode;
Jamie Madill1b94d432015-08-07 13:23:23 -0400399 mDirtyBits.set(DIRTY_BIT_CULL_FACE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400400}
401
402void State::setFrontFace(GLenum front)
403{
404 mRasterizer.frontFace = front;
Jamie Madill1b94d432015-08-07 13:23:23 -0400405 mDirtyBits.set(DIRTY_BIT_FRONT_FACE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400406}
407
408bool State::isDepthTestEnabled() const
409{
410 return mDepthStencil.depthTest;
411}
412
413void State::setDepthTest(bool enabled)
414{
415 mDepthStencil.depthTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400416 mDirtyBits.set(DIRTY_BIT_DEPTH_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400417}
418
419void State::setDepthFunc(GLenum depthFunc)
420{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700421 mDepthStencil.depthFunc = depthFunc;
422 mDirtyBits.set(DIRTY_BIT_DEPTH_FUNC);
Shannon Woods53a94a82014-06-24 15:20:36 -0400423}
424
425void State::setDepthRange(float zNear, float zFar)
426{
427 mNearZ = zNear;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700428 mFarZ = zFar;
Jamie Madill1b94d432015-08-07 13:23:23 -0400429 mDirtyBits.set(DIRTY_BIT_DEPTH_RANGE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400430}
431
Geoff Langd42f5b82015-04-16 14:03:29 -0400432float State::getNearPlane() const
Shannon Woods53a94a82014-06-24 15:20:36 -0400433{
Geoff Langd42f5b82015-04-16 14:03:29 -0400434 return mNearZ;
435}
436
437float State::getFarPlane() const
438{
439 return mFarZ;
Shannon Woods53a94a82014-06-24 15:20:36 -0400440}
441
442bool State::isBlendEnabled() const
443{
444 return mBlend.blend;
445}
446
447void State::setBlend(bool enabled)
448{
449 mBlend.blend = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400450 mDirtyBits.set(DIRTY_BIT_BLEND_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400451}
452
453void State::setBlendFactors(GLenum sourceRGB, GLenum destRGB, GLenum sourceAlpha, GLenum destAlpha)
454{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700455 mBlend.sourceBlendRGB = sourceRGB;
456 mBlend.destBlendRGB = destRGB;
Shannon Woods53a94a82014-06-24 15:20:36 -0400457 mBlend.sourceBlendAlpha = sourceAlpha;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700458 mBlend.destBlendAlpha = destAlpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400459 mDirtyBits.set(DIRTY_BIT_BLEND_FUNCS);
Shannon Woods53a94a82014-06-24 15:20:36 -0400460}
461
462void State::setBlendColor(float red, float green, float blue, float alpha)
463{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700464 mBlendColor.red = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400465 mBlendColor.green = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700466 mBlendColor.blue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400467 mBlendColor.alpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400468 mDirtyBits.set(DIRTY_BIT_BLEND_COLOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400469}
470
471void State::setBlendEquation(GLenum rgbEquation, GLenum alphaEquation)
472{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700473 mBlend.blendEquationRGB = rgbEquation;
Shannon Woods53a94a82014-06-24 15:20:36 -0400474 mBlend.blendEquationAlpha = alphaEquation;
Jamie Madill1b94d432015-08-07 13:23:23 -0400475 mDirtyBits.set(DIRTY_BIT_BLEND_EQUATIONS);
Shannon Woods53a94a82014-06-24 15:20:36 -0400476}
477
478const ColorF &State::getBlendColor() const
479{
480 return mBlendColor;
481}
482
483bool State::isStencilTestEnabled() const
484{
485 return mDepthStencil.stencilTest;
486}
487
488void State::setStencilTest(bool enabled)
489{
490 mDepthStencil.stencilTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400491 mDirtyBits.set(DIRTY_BIT_STENCIL_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400492}
493
494void State::setStencilParams(GLenum stencilFunc, GLint stencilRef, GLuint stencilMask)
495{
496 mDepthStencil.stencilFunc = stencilFunc;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700497 mStencilRef = (stencilRef > 0) ? stencilRef : 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400498 mDepthStencil.stencilMask = stencilMask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400499 mDirtyBits.set(DIRTY_BIT_STENCIL_FUNCS_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400500}
501
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700502void State::setStencilBackParams(GLenum stencilBackFunc,
503 GLint stencilBackRef,
504 GLuint stencilBackMask)
Shannon Woods53a94a82014-06-24 15:20:36 -0400505{
506 mDepthStencil.stencilBackFunc = stencilBackFunc;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700507 mStencilBackRef = (stencilBackRef > 0) ? stencilBackRef : 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400508 mDepthStencil.stencilBackMask = stencilBackMask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400509 mDirtyBits.set(DIRTY_BIT_STENCIL_FUNCS_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400510}
511
512void State::setStencilWritemask(GLuint stencilWritemask)
513{
514 mDepthStencil.stencilWritemask = stencilWritemask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400515 mDirtyBits.set(DIRTY_BIT_STENCIL_WRITEMASK_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400516}
517
518void State::setStencilBackWritemask(GLuint stencilBackWritemask)
519{
520 mDepthStencil.stencilBackWritemask = stencilBackWritemask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400521 mDirtyBits.set(DIRTY_BIT_STENCIL_WRITEMASK_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400522}
523
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700524void State::setStencilOperations(GLenum stencilFail,
525 GLenum stencilPassDepthFail,
526 GLenum stencilPassDepthPass)
Shannon Woods53a94a82014-06-24 15:20:36 -0400527{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700528 mDepthStencil.stencilFail = stencilFail;
Shannon Woods53a94a82014-06-24 15:20:36 -0400529 mDepthStencil.stencilPassDepthFail = stencilPassDepthFail;
530 mDepthStencil.stencilPassDepthPass = stencilPassDepthPass;
Jamie Madill1b94d432015-08-07 13:23:23 -0400531 mDirtyBits.set(DIRTY_BIT_STENCIL_OPS_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400532}
533
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700534void State::setStencilBackOperations(GLenum stencilBackFail,
535 GLenum stencilBackPassDepthFail,
536 GLenum stencilBackPassDepthPass)
Shannon Woods53a94a82014-06-24 15:20:36 -0400537{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700538 mDepthStencil.stencilBackFail = stencilBackFail;
Shannon Woods53a94a82014-06-24 15:20:36 -0400539 mDepthStencil.stencilBackPassDepthFail = stencilBackPassDepthFail;
540 mDepthStencil.stencilBackPassDepthPass = stencilBackPassDepthPass;
Jamie Madill1b94d432015-08-07 13:23:23 -0400541 mDirtyBits.set(DIRTY_BIT_STENCIL_OPS_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400542}
543
544GLint State::getStencilRef() const
545{
546 return mStencilRef;
547}
548
549GLint State::getStencilBackRef() const
550{
551 return mStencilBackRef;
552}
553
554bool State::isPolygonOffsetFillEnabled() const
555{
556 return mRasterizer.polygonOffsetFill;
557}
558
559void State::setPolygonOffsetFill(bool enabled)
560{
Jamie Madill1b94d432015-08-07 13:23:23 -0400561 mRasterizer.polygonOffsetFill = enabled;
562 mDirtyBits.set(DIRTY_BIT_POLYGON_OFFSET_FILL_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400563}
564
565void State::setPolygonOffsetParams(GLfloat factor, GLfloat units)
566{
567 // An application can pass NaN values here, so handle this gracefully
568 mRasterizer.polygonOffsetFactor = factor != factor ? 0.0f : factor;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700569 mRasterizer.polygonOffsetUnits = units != units ? 0.0f : units;
Jamie Madill1b94d432015-08-07 13:23:23 -0400570 mDirtyBits.set(DIRTY_BIT_POLYGON_OFFSET);
Shannon Woods53a94a82014-06-24 15:20:36 -0400571}
572
573bool State::isSampleAlphaToCoverageEnabled() const
574{
575 return mBlend.sampleAlphaToCoverage;
576}
577
578void State::setSampleAlphaToCoverage(bool enabled)
579{
580 mBlend.sampleAlphaToCoverage = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400581 mDirtyBits.set(DIRTY_BIT_SAMPLE_ALPHA_TO_COVERAGE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400582}
583
584bool State::isSampleCoverageEnabled() const
585{
586 return mSampleCoverage;
587}
588
589void State::setSampleCoverage(bool enabled)
590{
591 mSampleCoverage = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400592 mDirtyBits.set(DIRTY_BIT_SAMPLE_COVERAGE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400593}
594
595void State::setSampleCoverageParams(GLclampf value, bool invert)
596{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700597 mSampleCoverageValue = value;
Shannon Woods53a94a82014-06-24 15:20:36 -0400598 mSampleCoverageInvert = invert;
Jamie Madill1b94d432015-08-07 13:23:23 -0400599 mDirtyBits.set(DIRTY_BIT_SAMPLE_COVERAGE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400600}
601
Geoff Lang0fbb6002015-04-16 11:11:53 -0400602GLclampf State::getSampleCoverageValue() const
Shannon Woods53a94a82014-06-24 15:20:36 -0400603{
Geoff Lang0fbb6002015-04-16 11:11:53 -0400604 return mSampleCoverageValue;
605}
Shannon Woods53a94a82014-06-24 15:20:36 -0400606
Geoff Lang0fbb6002015-04-16 11:11:53 -0400607bool State::getSampleCoverageInvert() const
608{
609 return mSampleCoverageInvert;
Shannon Woods53a94a82014-06-24 15:20:36 -0400610}
611
Jiawei Shaodb342272017-09-27 10:21:45 +0800612bool State::isSampleMaskEnabled() const
613{
614 return mSampleMask;
615}
616
617void State::setSampleMaskEnabled(bool enabled)
618{
619 mSampleMask = enabled;
620 mDirtyBits.set(DIRTY_BIT_SAMPLE_MASK_ENABLED);
621}
622
623void State::setSampleMaskParams(GLuint maskNumber, GLbitfield mask)
624{
625 ASSERT(maskNumber < mMaxSampleMaskWords);
626 mSampleMaskValues[maskNumber] = mask;
Jamie Madillc67323a2017-11-02 23:11:41 -0400627 // TODO(jmadill): Use a child dirty bit if we ever use more than two words.
628 mDirtyBits.set(DIRTY_BIT_SAMPLE_MASK);
Jiawei Shaodb342272017-09-27 10:21:45 +0800629}
630
631GLbitfield State::getSampleMaskWord(GLuint maskNumber) const
632{
633 ASSERT(maskNumber < mMaxSampleMaskWords);
634 return mSampleMaskValues[maskNumber];
635}
636
637GLuint State::getMaxSampleMaskWords() const
638{
639 return mMaxSampleMaskWords;
640}
641
Sami Väisänen74c23472016-05-09 17:30:30 +0300642void State::setSampleAlphaToOne(bool enabled)
643{
644 mSampleAlphaToOne = enabled;
645 mDirtyBits.set(DIRTY_BIT_SAMPLE_ALPHA_TO_ONE);
646}
647
648bool State::isSampleAlphaToOneEnabled() const
649{
650 return mSampleAlphaToOne;
651}
652
653void State::setMultisampling(bool enabled)
654{
655 mMultiSampling = enabled;
656 mDirtyBits.set(DIRTY_BIT_MULTISAMPLING);
657}
658
659bool State::isMultisamplingEnabled() const
660{
661 return mMultiSampling;
662}
663
Shannon Woods53a94a82014-06-24 15:20:36 -0400664bool State::isScissorTestEnabled() const
665{
666 return mScissorTest;
667}
668
669void State::setScissorTest(bool enabled)
670{
671 mScissorTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400672 mDirtyBits.set(DIRTY_BIT_SCISSOR_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400673}
674
675void State::setScissorParams(GLint x, GLint y, GLsizei width, GLsizei height)
676{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700677 mScissor.x = x;
678 mScissor.y = y;
679 mScissor.width = width;
Shannon Woods53a94a82014-06-24 15:20:36 -0400680 mScissor.height = height;
Jamie Madill1b94d432015-08-07 13:23:23 -0400681 mDirtyBits.set(DIRTY_BIT_SCISSOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400682}
683
684const Rectangle &State::getScissor() const
685{
686 return mScissor;
687}
688
689bool State::isDitherEnabled() const
690{
691 return mBlend.dither;
692}
693
694void State::setDither(bool enabled)
695{
696 mBlend.dither = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400697 mDirtyBits.set(DIRTY_BIT_DITHER_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400698}
699
Jamie Madillb4b53c52015-02-03 15:22:48 -0500700bool State::isPrimitiveRestartEnabled() const
701{
702 return mPrimitiveRestart;
703}
704
705void State::setPrimitiveRestart(bool enabled)
706{
707 mPrimitiveRestart = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400708 mDirtyBits.set(DIRTY_BIT_PRIMITIVE_RESTART_ENABLED);
Jamie Madillb4b53c52015-02-03 15:22:48 -0500709}
710
Shannon Woods53a94a82014-06-24 15:20:36 -0400711void State::setEnableFeature(GLenum feature, bool enabled)
712{
713 switch (feature)
714 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700715 case GL_MULTISAMPLE_EXT:
716 setMultisampling(enabled);
717 break;
718 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
719 setSampleAlphaToOne(enabled);
720 break;
721 case GL_CULL_FACE:
722 setCullFace(enabled);
723 break;
724 case GL_POLYGON_OFFSET_FILL:
725 setPolygonOffsetFill(enabled);
726 break;
727 case GL_SAMPLE_ALPHA_TO_COVERAGE:
728 setSampleAlphaToCoverage(enabled);
729 break;
730 case GL_SAMPLE_COVERAGE:
731 setSampleCoverage(enabled);
732 break;
733 case GL_SCISSOR_TEST:
734 setScissorTest(enabled);
735 break;
736 case GL_STENCIL_TEST:
737 setStencilTest(enabled);
738 break;
739 case GL_DEPTH_TEST:
740 setDepthTest(enabled);
741 break;
742 case GL_BLEND:
743 setBlend(enabled);
744 break;
745 case GL_DITHER:
746 setDither(enabled);
747 break;
748 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
749 setPrimitiveRestart(enabled);
750 break;
751 case GL_RASTERIZER_DISCARD:
752 setRasterizerDiscard(enabled);
753 break;
754 case GL_SAMPLE_MASK:
755 setSampleMaskEnabled(enabled);
756 break;
757 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
758 mDebug.setOutputSynchronous(enabled);
759 break;
760 case GL_DEBUG_OUTPUT:
761 mDebug.setOutputEnabled(enabled);
762 break;
763 case GL_FRAMEBUFFER_SRGB_EXT:
764 setFramebufferSRGB(enabled);
765 break;
766 default:
767 UNREACHABLE();
Shannon Woods53a94a82014-06-24 15:20:36 -0400768 }
769}
770
Jamie Madilldfde6ab2016-06-09 07:07:18 -0700771bool State::getEnableFeature(GLenum feature) const
Shannon Woods53a94a82014-06-24 15:20:36 -0400772{
773 switch (feature)
774 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700775 case GL_MULTISAMPLE_EXT:
776 return isMultisamplingEnabled();
777 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
778 return isSampleAlphaToOneEnabled();
779 case GL_CULL_FACE:
780 return isCullFaceEnabled();
781 case GL_POLYGON_OFFSET_FILL:
782 return isPolygonOffsetFillEnabled();
783 case GL_SAMPLE_ALPHA_TO_COVERAGE:
784 return isSampleAlphaToCoverageEnabled();
785 case GL_SAMPLE_COVERAGE:
786 return isSampleCoverageEnabled();
787 case GL_SCISSOR_TEST:
788 return isScissorTestEnabled();
789 case GL_STENCIL_TEST:
790 return isStencilTestEnabled();
791 case GL_DEPTH_TEST:
792 return isDepthTestEnabled();
793 case GL_BLEND:
794 return isBlendEnabled();
795 case GL_DITHER:
796 return isDitherEnabled();
797 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
798 return isPrimitiveRestartEnabled();
799 case GL_RASTERIZER_DISCARD:
800 return isRasterizerDiscardEnabled();
801 case GL_SAMPLE_MASK:
802 return isSampleMaskEnabled();
803 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
804 return mDebug.isOutputSynchronous();
805 case GL_DEBUG_OUTPUT:
806 return mDebug.isOutputEnabled();
807 case GL_BIND_GENERATES_RESOURCE_CHROMIUM:
808 return isBindGeneratesResourceEnabled();
809 case GL_CLIENT_ARRAYS_ANGLE:
810 return areClientArraysEnabled();
811 case GL_FRAMEBUFFER_SRGB_EXT:
812 return getFramebufferSRGB();
813 case GL_ROBUST_RESOURCE_INITIALIZATION_ANGLE:
814 return mRobustResourceInit;
815 case GL_PROGRAM_CACHE_ENABLED_ANGLE:
816 return mProgramBinaryCacheEnabled;
Jamie Madillc43be722017-07-13 16:22:14 -0400817
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700818 default:
819 UNREACHABLE();
820 return false;
Shannon Woods53a94a82014-06-24 15:20:36 -0400821 }
822}
823
824void State::setLineWidth(GLfloat width)
825{
826 mLineWidth = width;
Jamie Madill1b94d432015-08-07 13:23:23 -0400827 mDirtyBits.set(DIRTY_BIT_LINE_WIDTH);
Shannon Woods53a94a82014-06-24 15:20:36 -0400828}
829
Geoff Lang4b3f4162015-04-16 13:22:05 -0400830float State::getLineWidth() const
831{
832 return mLineWidth;
833}
834
Shannon Woods53a94a82014-06-24 15:20:36 -0400835void State::setGenerateMipmapHint(GLenum hint)
836{
837 mGenerateMipmapHint = hint;
Jamie Madill1b94d432015-08-07 13:23:23 -0400838 mDirtyBits.set(DIRTY_BIT_GENERATE_MIPMAP_HINT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400839}
840
841void State::setFragmentShaderDerivativeHint(GLenum hint)
842{
843 mFragmentShaderDerivativeHint = hint;
Jamie Madill1b94d432015-08-07 13:23:23 -0400844 mDirtyBits.set(DIRTY_BIT_SHADER_DERIVATIVE_HINT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400845 // TODO: Propagate the hint to shader translator so we can write
846 // ddx, ddx_coarse, or ddx_fine depending on the hint.
847 // Ignore for now. It is valid for implementations to ignore hint.
848}
849
Geoff Langf41a7152016-09-19 15:11:17 -0400850bool State::isBindGeneratesResourceEnabled() const
851{
852 return mBindGeneratesResource;
853}
854
Geoff Langfeb8c682017-02-13 16:07:35 -0500855bool State::areClientArraysEnabled() const
856{
857 return mClientArraysEnabled;
858}
859
Shannon Woods53a94a82014-06-24 15:20:36 -0400860void State::setViewportParams(GLint x, GLint y, GLsizei width, GLsizei height)
861{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700862 mViewport.x = x;
863 mViewport.y = y;
864 mViewport.width = width;
Shannon Woods53a94a82014-06-24 15:20:36 -0400865 mViewport.height = height;
Jamie Madill1b94d432015-08-07 13:23:23 -0400866 mDirtyBits.set(DIRTY_BIT_VIEWPORT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400867}
868
869const Rectangle &State::getViewport() const
870{
871 return mViewport;
872}
873
874void State::setActiveSampler(unsigned int active)
875{
876 mActiveSampler = active;
877}
878
879unsigned int State::getActiveSampler() const
880{
Cooper Partin4d61f7e2015-08-12 10:56:50 -0700881 return static_cast<unsigned int>(mActiveSampler);
Shannon Woods53a94a82014-06-24 15:20:36 -0400882}
883
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800884void State::setSamplerTexture(const Context *context, TextureType type, Texture *texture)
Shannon Woods53a94a82014-06-24 15:20:36 -0400885{
Jamie Madill4928b7c2017-06-20 12:57:39 -0400886 mSamplerTextures[type][mActiveSampler].set(context, texture);
Jamie Madill81c2e252017-09-09 23:32:46 -0400887 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
888 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Shannon Woods53a94a82014-06-24 15:20:36 -0400889}
890
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800891Texture *State::getTargetTexture(TextureType type) const
Jamie Madillc29968b2016-01-20 11:17:23 -0500892{
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800893 return getSamplerTexture(static_cast<unsigned int>(mActiveSampler), type);
Jamie Madillc29968b2016-01-20 11:17:23 -0500894}
895
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800896Texture *State::getSamplerTexture(unsigned int sampler, TextureType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -0400897{
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800898 ASSERT(sampler < mSamplerTextures[type].size());
899 return mSamplerTextures[type][sampler].get();
Shannon Woods53a94a82014-06-24 15:20:36 -0400900}
901
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800902GLuint State::getSamplerTextureId(unsigned int sampler, TextureType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -0400903{
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800904 ASSERT(sampler < mSamplerTextures[type].size());
905 return mSamplerTextures[type][sampler].id();
Shannon Woods53a94a82014-06-24 15:20:36 -0400906}
907
Jamie Madilla02315b2017-02-23 14:14:47 -0500908void State::detachTexture(const Context *context, const TextureMap &zeroTextures, GLuint texture)
Shannon Woods53a94a82014-06-24 15:20:36 -0400909{
910 // Textures have a detach method on State rather than a simple
911 // removeBinding, because the zero/null texture objects are managed
912 // separately, and don't have to go through the Context's maps or
913 // the ResourceManager.
914
915 // [OpenGL ES 2.0.24] section 3.8 page 84:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700916 // If a texture object is deleted, it is as if all texture units which are bound to that texture
917 // object are rebound to texture object zero
Shannon Woods53a94a82014-06-24 15:20:36 -0400918
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800919 for (TextureType type : angle::AllEnums<TextureType>())
Shannon Woods53a94a82014-06-24 15:20:36 -0400920 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800921 TextureBindingVector &textureVector = mSamplerTextures[type];
Jamie Madill81c2e252017-09-09 23:32:46 -0400922 for (BindingPointer<Texture> &binding : textureVector)
Shannon Woods53a94a82014-06-24 15:20:36 -0400923 {
Geoff Lang76b10c92014-09-05 16:28:14 -0400924 if (binding.id() == texture)
Shannon Woods53a94a82014-06-24 15:20:36 -0400925 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800926 Texture *zeroTexture = zeroTextures[type].get();
927 ASSERT(zeroTexture != nullptr);
Jamie Madille6382c32014-11-07 15:05:26 -0500928 // Zero textures are the "default" textures instead of NULL
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800929 binding.set(context, zeroTexture);
Jamie Madill81c2e252017-09-09 23:32:46 -0400930 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
Shannon Woods53a94a82014-06-24 15:20:36 -0400931 }
932 }
933 }
934
Xinghua Cao65ec0b22017-03-28 16:10:52 +0800935 for (auto &bindingImageUnit : mImageUnits)
936 {
937 if (bindingImageUnit.texture.id() == texture)
938 {
939 bindingImageUnit.texture.set(context, nullptr);
940 bindingImageUnit.level = 0;
941 bindingImageUnit.layered = false;
942 bindingImageUnit.layer = 0;
943 bindingImageUnit.access = GL_READ_ONLY;
944 bindingImageUnit.format = GL_R32UI;
945 break;
946 }
947 }
948
Shannon Woods53a94a82014-06-24 15:20:36 -0400949 // [OpenGL ES 2.0.24] section 4.4 page 112:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700950 // If a texture object is deleted while its image is attached to the currently bound
951 // framebuffer, then it is as if Texture2DAttachment had been called, with a texture of 0, for
952 // each attachment point to which this image was attached in the currently bound framebuffer.
Shannon Woods53a94a82014-06-24 15:20:36 -0400953
Jamie Madill8693bdb2017-09-02 15:32:14 -0400954 if (mReadFramebuffer && mReadFramebuffer->detachTexture(context, texture))
Shannon Woods53a94a82014-06-24 15:20:36 -0400955 {
Jamie Madill8693bdb2017-09-02 15:32:14 -0400956 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
Shannon Woods53a94a82014-06-24 15:20:36 -0400957 }
958
Jamie Madill8693bdb2017-09-02 15:32:14 -0400959 if (mDrawFramebuffer && mDrawFramebuffer->detachTexture(context, texture))
Shannon Woods53a94a82014-06-24 15:20:36 -0400960 {
Jamie Madill8693bdb2017-09-02 15:32:14 -0400961 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
Shannon Woods53a94a82014-06-24 15:20:36 -0400962 }
963}
964
Jamie Madill4928b7c2017-06-20 12:57:39 -0400965void State::initializeZeroTextures(const Context *context, const TextureMap &zeroTextures)
Jamie Madille6382c32014-11-07 15:05:26 -0500966{
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800967 for (TextureType type : angle::AllEnums<TextureType>())
Jamie Madille6382c32014-11-07 15:05:26 -0500968 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800969 for (size_t textureUnit = 0; textureUnit < mSamplerTextures[type].size(); ++textureUnit)
Jamie Madille6382c32014-11-07 15:05:26 -0500970 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800971 mSamplerTextures[type][textureUnit].set(context, zeroTextures[type].get());
Jamie Madille6382c32014-11-07 15:05:26 -0500972 }
973 }
974}
975
Jamie Madill4928b7c2017-06-20 12:57:39 -0400976void State::setSamplerBinding(const Context *context, GLuint textureUnit, Sampler *sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -0400977{
Jamie Madill4928b7c2017-06-20 12:57:39 -0400978 mSamplers[textureUnit].set(context, sampler);
Jamie Madill81c2e252017-09-09 23:32:46 -0400979 mDirtyBits.set(DIRTY_BIT_SAMPLER_BINDINGS);
980 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Shannon Woods53a94a82014-06-24 15:20:36 -0400981}
982
983GLuint State::getSamplerId(GLuint textureUnit) const
984{
Geoff Lang76b10c92014-09-05 16:28:14 -0400985 ASSERT(textureUnit < mSamplers.size());
Shannon Woods53a94a82014-06-24 15:20:36 -0400986 return mSamplers[textureUnit].id();
987}
988
989Sampler *State::getSampler(GLuint textureUnit) const
990{
991 return mSamplers[textureUnit].get();
992}
993
Jamie Madill4928b7c2017-06-20 12:57:39 -0400994void State::detachSampler(const Context *context, GLuint sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -0400995{
996 // [OpenGL ES 3.0.2] section 3.8.2 pages 123-124:
997 // If a sampler object that is currently bound to one or more texture units is
998 // deleted, it is as though BindSampler is called once for each texture unit to
999 // which the sampler is bound, with unit set to the texture unit and sampler set to zero.
Jamie Madill81c2e252017-09-09 23:32:46 -04001000 for (BindingPointer<Sampler> &samplerBinding : mSamplers)
Shannon Woods53a94a82014-06-24 15:20:36 -04001001 {
Geoff Lang76b10c92014-09-05 16:28:14 -04001002 if (samplerBinding.id() == sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001003 {
Jamie Madill4928b7c2017-06-20 12:57:39 -04001004 samplerBinding.set(context, nullptr);
Jamie Madill81c2e252017-09-09 23:32:46 -04001005 mDirtyBits.set(DIRTY_BIT_SAMPLER_BINDINGS);
Shannon Woods53a94a82014-06-24 15:20:36 -04001006 }
1007 }
1008}
1009
Jamie Madill4928b7c2017-06-20 12:57:39 -04001010void State::setRenderbufferBinding(const Context *context, Renderbuffer *renderbuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001011{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001012 mRenderbuffer.set(context, renderbuffer);
Jamie Madill8693bdb2017-09-02 15:32:14 -04001013 mDirtyBits.set(DIRTY_BIT_RENDERBUFFER_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001014}
1015
1016GLuint State::getRenderbufferId() const
1017{
1018 return mRenderbuffer.id();
1019}
1020
Jamie Madilldfde6ab2016-06-09 07:07:18 -07001021Renderbuffer *State::getCurrentRenderbuffer() const
Shannon Woods53a94a82014-06-24 15:20:36 -04001022{
1023 return mRenderbuffer.get();
1024}
1025
Jamie Madilla02315b2017-02-23 14:14:47 -05001026void State::detachRenderbuffer(const Context *context, GLuint renderbuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001027{
1028 // [OpenGL ES 2.0.24] section 4.4 page 109:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001029 // If a renderbuffer that is currently bound to RENDERBUFFER is deleted, it is as though
1030 // BindRenderbuffer had been executed with the target RENDERBUFFER and name of zero.
Shannon Woods53a94a82014-06-24 15:20:36 -04001031
1032 if (mRenderbuffer.id() == renderbuffer)
1033 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001034 setRenderbufferBinding(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001035 }
1036
1037 // [OpenGL ES 2.0.24] section 4.4 page 111:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001038 // If a renderbuffer object is deleted while its image is attached to the currently bound
1039 // framebuffer, then it is as if FramebufferRenderbuffer had been called, with a renderbuffer of
1040 // 0, for each attachment point to which this image was attached in the currently bound
1041 // framebuffer.
Shannon Woods53a94a82014-06-24 15:20:36 -04001042
1043 Framebuffer *readFramebuffer = mReadFramebuffer;
1044 Framebuffer *drawFramebuffer = mDrawFramebuffer;
1045
Jamie Madill8693bdb2017-09-02 15:32:14 -04001046 if (readFramebuffer && readFramebuffer->detachRenderbuffer(context, renderbuffer))
Shannon Woods53a94a82014-06-24 15:20:36 -04001047 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001048 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
Shannon Woods53a94a82014-06-24 15:20:36 -04001049 }
1050
1051 if (drawFramebuffer && drawFramebuffer != readFramebuffer)
1052 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001053 if (drawFramebuffer->detachRenderbuffer(context, renderbuffer))
1054 {
1055 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
1056 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001057 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001058}
1059
1060void State::setReadFramebufferBinding(Framebuffer *framebuffer)
1061{
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001062 if (mReadFramebuffer == framebuffer)
1063 return;
1064
Shannon Woods53a94a82014-06-24 15:20:36 -04001065 mReadFramebuffer = framebuffer;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001066 mDirtyBits.set(DIRTY_BIT_READ_FRAMEBUFFER_BINDING);
1067
1068 if (mReadFramebuffer && mReadFramebuffer->hasAnyDirtyBit())
1069 {
1070 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
1071 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001072}
1073
1074void State::setDrawFramebufferBinding(Framebuffer *framebuffer)
1075{
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001076 if (mDrawFramebuffer == framebuffer)
1077 return;
1078
Shannon Woods53a94a82014-06-24 15:20:36 -04001079 mDrawFramebuffer = framebuffer;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001080 mDirtyBits.set(DIRTY_BIT_DRAW_FRAMEBUFFER_BINDING);
1081
1082 if (mDrawFramebuffer && mDrawFramebuffer->hasAnyDirtyBit())
1083 {
1084 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
1085 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001086}
1087
1088Framebuffer *State::getTargetFramebuffer(GLenum target) const
1089{
1090 switch (target)
1091 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001092 case GL_READ_FRAMEBUFFER_ANGLE:
1093 return mReadFramebuffer;
1094 case GL_DRAW_FRAMEBUFFER_ANGLE:
1095 case GL_FRAMEBUFFER:
1096 return mDrawFramebuffer;
1097 default:
1098 UNREACHABLE();
Yunchao Hef81ce4a2017-04-24 10:49:17 +08001099 return nullptr;
Shannon Woods53a94a82014-06-24 15:20:36 -04001100 }
1101}
1102
Jamie Madill51f40ec2016-06-15 14:06:00 -04001103Framebuffer *State::getReadFramebuffer() const
Shannon Woods53a94a82014-06-24 15:20:36 -04001104{
1105 return mReadFramebuffer;
1106}
1107
Jamie Madill51f40ec2016-06-15 14:06:00 -04001108Framebuffer *State::getDrawFramebuffer() const
Shannon Woods53a94a82014-06-24 15:20:36 -04001109{
1110 return mDrawFramebuffer;
1111}
1112
1113bool State::removeReadFramebufferBinding(GLuint framebuffer)
1114{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001115 if (mReadFramebuffer != nullptr && mReadFramebuffer->id() == framebuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001116 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001117 setReadFramebufferBinding(nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001118 return true;
1119 }
1120
1121 return false;
1122}
1123
1124bool State::removeDrawFramebufferBinding(GLuint framebuffer)
1125{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001126 if (mReadFramebuffer != nullptr && mDrawFramebuffer->id() == framebuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001127 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001128 setDrawFramebufferBinding(nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001129 return true;
1130 }
1131
1132 return false;
1133}
1134
1135void State::setVertexArrayBinding(VertexArray *vertexArray)
1136{
James Darpiniane8a93c62018-01-04 18:02:24 -08001137 if (mVertexArray == vertexArray)
1138 return;
1139 if (mVertexArray)
1140 mVertexArray->onBindingChanged(false);
Shannon Woods53a94a82014-06-24 15:20:36 -04001141 mVertexArray = vertexArray;
James Darpiniane8a93c62018-01-04 18:02:24 -08001142 if (vertexArray)
1143 vertexArray->onBindingChanged(true);
Jamie Madill0b9e9032015-08-17 11:51:52 +00001144 mDirtyBits.set(DIRTY_BIT_VERTEX_ARRAY_BINDING);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001145
1146 if (mVertexArray && mVertexArray->hasAnyDirtyBit())
1147 {
1148 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1149 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001150}
1151
1152GLuint State::getVertexArrayId() const
1153{
Yunchao He4f285442017-04-21 12:15:49 +08001154 ASSERT(mVertexArray != nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001155 return mVertexArray->id();
1156}
1157
1158VertexArray *State::getVertexArray() const
1159{
Yunchao He4f285442017-04-21 12:15:49 +08001160 ASSERT(mVertexArray != nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001161 return mVertexArray;
1162}
1163
1164bool State::removeVertexArrayBinding(GLuint vertexArray)
1165{
James Darpiniane8a93c62018-01-04 18:02:24 -08001166 if (mVertexArray && mVertexArray->id() == vertexArray)
Shannon Woods53a94a82014-06-24 15:20:36 -04001167 {
James Darpiniane8a93c62018-01-04 18:02:24 -08001168 mVertexArray->onBindingChanged(false);
Yunchao Hed7297bf2017-04-19 15:27:10 +08001169 mVertexArray = nullptr;
Jamie Madill0b9e9032015-08-17 11:51:52 +00001170 mDirtyBits.set(DIRTY_BIT_VERTEX_ARRAY_BINDING);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001171 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001172 return true;
1173 }
1174
1175 return false;
1176}
1177
Jamie Madill4928b7c2017-06-20 12:57:39 -04001178void State::bindVertexBuffer(const Context *context,
1179 GLuint bindingIndex,
Shao80957d92017-02-20 21:25:59 +08001180 Buffer *boundBuffer,
1181 GLintptr offset,
1182 GLsizei stride)
1183{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001184 getVertexArray()->bindVertexBuffer(context, bindingIndex, boundBuffer, offset, stride);
Shao80957d92017-02-20 21:25:59 +08001185 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1186}
1187
Shaodde78e82017-05-22 14:13:27 +08001188void State::setVertexAttribBinding(const Context *context, GLuint attribIndex, GLuint bindingIndex)
Shao80957d92017-02-20 21:25:59 +08001189{
Shaodde78e82017-05-22 14:13:27 +08001190 getVertexArray()->setVertexAttribBinding(context, attribIndex, bindingIndex);
Shao80957d92017-02-20 21:25:59 +08001191 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1192}
1193
1194void State::setVertexAttribFormat(GLuint attribIndex,
1195 GLint size,
1196 GLenum type,
1197 bool normalized,
1198 bool pureInteger,
1199 GLuint relativeOffset)
1200{
1201 getVertexArray()->setVertexAttribFormat(attribIndex, size, type, normalized, pureInteger,
1202 relativeOffset);
1203 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1204}
1205
1206void State::setVertexBindingDivisor(GLuint bindingIndex, GLuint divisor)
1207{
1208 getVertexArray()->setVertexBindingDivisor(bindingIndex, divisor);
1209 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1210}
1211
Jamie Madill6c1f6712017-02-14 19:08:04 -05001212void State::setProgram(const Context *context, Program *newProgram)
Shannon Woods53a94a82014-06-24 15:20:36 -04001213{
Geoff Lang7dd2e102014-11-10 15:19:26 -05001214 if (mProgram != newProgram)
Shannon Woods53a94a82014-06-24 15:20:36 -04001215 {
Geoff Lang7dd2e102014-11-10 15:19:26 -05001216 if (mProgram)
1217 {
Jamie Madill6c1f6712017-02-14 19:08:04 -05001218 mProgram->release(context);
Geoff Lang7dd2e102014-11-10 15:19:26 -05001219 }
1220
1221 mProgram = newProgram;
1222
1223 if (mProgram)
1224 {
1225 newProgram->addRef();
Jamie Madill81c2e252017-09-09 23:32:46 -04001226 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Geoff Lang7dd2e102014-11-10 15:19:26 -05001227 }
Jamie Madilla779b612017-07-24 11:46:05 -04001228 mDirtyBits.set(DIRTY_BIT_PROGRAM_EXECUTABLE);
1229 mDirtyBits.set(DIRTY_BIT_PROGRAM_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001230 }
1231}
1232
Geoff Lang7dd2e102014-11-10 15:19:26 -05001233Program *State::getProgram() const
Shannon Woods53a94a82014-06-24 15:20:36 -04001234{
Geoff Lang7dd2e102014-11-10 15:19:26 -05001235 return mProgram;
Shannon Woods53a94a82014-06-24 15:20:36 -04001236}
1237
Jamie Madill4928b7c2017-06-20 12:57:39 -04001238void State::setTransformFeedbackBinding(const Context *context,
1239 TransformFeedback *transformFeedback)
Shannon Woods53a94a82014-06-24 15:20:36 -04001240{
James Darpiniane8a93c62018-01-04 18:02:24 -08001241 if (transformFeedback == mTransformFeedback.get())
1242 return;
1243 if (mTransformFeedback.get())
1244 mTransformFeedback->onBindingChanged(false);
Jamie Madill4928b7c2017-06-20 12:57:39 -04001245 mTransformFeedback.set(context, transformFeedback);
James Darpiniane8a93c62018-01-04 18:02:24 -08001246 if (mTransformFeedback.get())
1247 mTransformFeedback->onBindingChanged(true);
Geoff Langded79232017-11-28 15:21:11 -05001248 mDirtyBits.set(DIRTY_BIT_TRANSFORM_FEEDBACK_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001249}
1250
1251TransformFeedback *State::getCurrentTransformFeedback() const
1252{
1253 return mTransformFeedback.get();
1254}
1255
Gregoire Payen de La Garanderie52742022015-02-04 14:55:39 +00001256bool State::isTransformFeedbackActiveUnpaused() const
1257{
Jamie Madill81c2e252017-09-09 23:32:46 -04001258 TransformFeedback *curTransformFeedback = getCurrentTransformFeedback();
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001259 return curTransformFeedback && curTransformFeedback->isActive() &&
1260 !curTransformFeedback->isPaused();
Gregoire Payen de La Garanderie52742022015-02-04 14:55:39 +00001261}
1262
Jamie Madill4928b7c2017-06-20 12:57:39 -04001263bool State::removeTransformFeedbackBinding(const Context *context, GLuint transformFeedback)
Shannon Woods53a94a82014-06-24 15:20:36 -04001264{
1265 if (mTransformFeedback.id() == transformFeedback)
1266 {
James Darpiniane8a93c62018-01-04 18:02:24 -08001267 if (mTransformFeedback.get())
1268 mTransformFeedback->onBindingChanged(false);
Jamie Madill4928b7c2017-06-20 12:57:39 -04001269 mTransformFeedback.set(context, nullptr);
Corentin Walleza2257da2016-04-19 16:43:12 -04001270 return true;
Shannon Woods53a94a82014-06-24 15:20:36 -04001271 }
Corentin Walleza2257da2016-04-19 16:43:12 -04001272
1273 return false;
Shannon Woods53a94a82014-06-24 15:20:36 -04001274}
1275
Yunchao Hea336b902017-08-02 16:05:21 +08001276void State::setProgramPipelineBinding(const Context *context, ProgramPipeline *pipeline)
1277{
1278 mProgramPipeline.set(context, pipeline);
1279}
1280
1281void State::detachProgramPipeline(const Context *context, GLuint pipeline)
1282{
1283 mProgramPipeline.set(context, nullptr);
1284}
1285
Olli Etuahobbf1c102016-06-28 13:31:33 +03001286bool State::isQueryActive(const GLenum type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001287{
Ian Ewell3ffd78b2016-01-22 16:09:42 -05001288 for (auto &iter : mActiveQueries)
Shannon Woods53a94a82014-06-24 15:20:36 -04001289 {
Olli Etuahobbf1c102016-06-28 13:31:33 +03001290 const Query *query = iter.second.get();
1291 if (query != nullptr && ActiveQueryType(query->getType()) == ActiveQueryType(type))
Ian Ewell3ffd78b2016-01-22 16:09:42 -05001292 {
1293 return true;
1294 }
1295 }
1296
1297 return false;
1298}
1299
1300bool State::isQueryActive(Query *query) const
1301{
1302 for (auto &iter : mActiveQueries)
1303 {
1304 if (iter.second.get() == query)
Shannon Woods53a94a82014-06-24 15:20:36 -04001305 {
1306 return true;
1307 }
1308 }
1309
1310 return false;
1311}
1312
Jamie Madill4928b7c2017-06-20 12:57:39 -04001313void State::setActiveQuery(const Context *context, GLenum target, Query *query)
Shannon Woods53a94a82014-06-24 15:20:36 -04001314{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001315 mActiveQueries[target].set(context, query);
Shannon Woods53a94a82014-06-24 15:20:36 -04001316}
1317
1318GLuint State::getActiveQueryId(GLenum target) const
1319{
1320 const Query *query = getActiveQuery(target);
1321 return (query ? query->id() : 0u);
1322}
1323
1324Query *State::getActiveQuery(GLenum target) const
1325{
Jamie Madill5864ac22015-01-12 14:43:07 -05001326 const auto it = mActiveQueries.find(target);
Shannon Woods53a94a82014-06-24 15:20:36 -04001327
Jamie Madill5864ac22015-01-12 14:43:07 -05001328 // All query types should already exist in the activeQueries map
1329 ASSERT(it != mActiveQueries.end());
1330
1331 return it->second.get();
Shannon Woods53a94a82014-06-24 15:20:36 -04001332}
1333
Corentin Wallez336129f2017-10-17 15:55:40 -04001334void State::setBufferBinding(const Context *context, BufferBinding target, Buffer *buffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001335{
Corentin Wallez336129f2017-10-17 15:55:40 -04001336 switch (target)
1337 {
1338 case BufferBinding::PixelPack:
James Darpiniane8a93c62018-01-04 18:02:24 -08001339 UpdateBufferBinding(context, &mBoundBuffers[target], buffer, target);
Corentin Wallez336129f2017-10-17 15:55:40 -04001340 mDirtyBits.set(DIRTY_BIT_PACK_BUFFER_BINDING);
1341 break;
1342 case BufferBinding::PixelUnpack:
James Darpiniane8a93c62018-01-04 18:02:24 -08001343 UpdateBufferBinding(context, &mBoundBuffers[target], buffer, target);
Corentin Wallez336129f2017-10-17 15:55:40 -04001344 mDirtyBits.set(DIRTY_BIT_UNPACK_BUFFER_BINDING);
1345 break;
1346 case BufferBinding::DrawIndirect:
James Darpiniane8a93c62018-01-04 18:02:24 -08001347 UpdateBufferBinding(context, &mBoundBuffers[target], buffer, target);
Corentin Wallez336129f2017-10-17 15:55:40 -04001348 mDirtyBits.set(DIRTY_BIT_DRAW_INDIRECT_BUFFER_BINDING);
1349 break;
Qin Jiajiaa98a2812017-11-30 18:12:06 +08001350 case BufferBinding::DispatchIndirect:
James Darpiniane8a93c62018-01-04 18:02:24 -08001351 UpdateBufferBinding(context, &mBoundBuffers[target], buffer, target);
Qin Jiajiaa98a2812017-11-30 18:12:06 +08001352 mDirtyBits.set(DIRTY_BIT_DISPATCH_INDIRECT_BUFFER_BINDING);
1353 break;
Corentin Wallez336129f2017-10-17 15:55:40 -04001354 case BufferBinding::ElementArray:
1355 getVertexArray()->setElementArrayBuffer(context, buffer);
1356 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1357 break;
Xinghua Cao10a4d432017-11-28 14:46:26 +08001358 case BufferBinding::ShaderStorage:
James Darpiniane8a93c62018-01-04 18:02:24 -08001359 UpdateBufferBinding(context, &mBoundBuffers[target], buffer, target);
Xinghua Cao10a4d432017-11-28 14:46:26 +08001360 mDirtyBits.set(DIRTY_BIT_SHADER_STORAGE_BUFFER_BINDING);
1361 break;
Corentin Wallez336129f2017-10-17 15:55:40 -04001362 default:
James Darpiniane8a93c62018-01-04 18:02:24 -08001363 UpdateBufferBinding(context, &mBoundBuffers[target], buffer, target);
Corentin Wallez336129f2017-10-17 15:55:40 -04001364 break;
1365 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001366}
James Darpiniane8a93c62018-01-04 18:02:24 -08001367
Corentin Wallez336129f2017-10-17 15:55:40 -04001368void State::setIndexedBufferBinding(const Context *context,
1369 BufferBinding target,
1370 GLuint index,
1371 Buffer *buffer,
1372 GLintptr offset,
1373 GLsizeiptr size)
Jiajia Qin9d7d0b12016-11-29 16:30:31 +08001374{
Corentin Wallez336129f2017-10-17 15:55:40 -04001375 setBufferBinding(context, target, buffer);
Jiajia Qin9d7d0b12016-11-29 16:30:31 +08001376
Corentin Wallez336129f2017-10-17 15:55:40 -04001377 switch (target)
1378 {
1379 case BufferBinding::TransformFeedback:
1380 mTransformFeedback->bindIndexedBuffer(context, index, buffer, offset, size);
James Darpiniane8a93c62018-01-04 18:02:24 -08001381 setBufferBinding(context, target, buffer);
Corentin Wallez336129f2017-10-17 15:55:40 -04001382 break;
1383 case BufferBinding::Uniform:
James Darpiniane8a93c62018-01-04 18:02:24 -08001384 UpdateBufferBinding(context, &mUniformBuffers[index], buffer, target, offset, size);
Jamie Madillf4141212017-12-12 15:08:07 -05001385 mDirtyBits.set(DIRTY_BIT_UNIFORM_BUFFER_BINDINGS);
Corentin Wallez336129f2017-10-17 15:55:40 -04001386 break;
1387 case BufferBinding::AtomicCounter:
James Darpiniane8a93c62018-01-04 18:02:24 -08001388 UpdateBufferBinding(context, &mAtomicCounterBuffers[index], buffer, target, offset,
1389 size);
Corentin Wallez336129f2017-10-17 15:55:40 -04001390 break;
1391 case BufferBinding::ShaderStorage:
James Darpiniane8a93c62018-01-04 18:02:24 -08001392 UpdateBufferBinding(context, &mShaderStorageBuffers[index], buffer, target, offset,
1393 size);
Corentin Wallez336129f2017-10-17 15:55:40 -04001394 break;
1395 default:
1396 UNREACHABLE();
1397 break;
1398 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001399}
1400
Geoff Lang5d124a62015-09-15 13:03:27 -04001401const OffsetBindingPointer<Buffer> &State::getIndexedUniformBuffer(size_t index) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001402{
Shannon Woodsf3acaf92014-09-23 18:07:11 -04001403 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
Geoff Lang5d124a62015-09-15 13:03:27 -04001404 return mUniformBuffers[index];
Gregoire Payen de La Garanderie68694e92015-03-24 14:03:37 +00001405}
1406
Jiajia Qin6eafb042016-12-27 17:04:07 +08001407const OffsetBindingPointer<Buffer> &State::getIndexedAtomicCounterBuffer(size_t index) const
1408{
1409 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
1410 return mAtomicCounterBuffers[index];
1411}
1412
Jiajia Qinf546e7d2017-03-27 14:12:59 +08001413const OffsetBindingPointer<Buffer> &State::getIndexedShaderStorageBuffer(size_t index) const
1414{
1415 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
1416 return mShaderStorageBuffers[index];
1417}
1418
Corentin Wallez336129f2017-10-17 15:55:40 -04001419Buffer *State::getTargetBuffer(BufferBinding target) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001420{
1421 switch (target)
1422 {
Corentin Wallez336129f2017-10-17 15:55:40 -04001423 case BufferBinding::ElementArray:
1424 return getVertexArray()->getElementArrayBuffer().get();
Corentin Wallez336129f2017-10-17 15:55:40 -04001425 default:
1426 return mBoundBuffers[target].get();
Shannon Woods53a94a82014-06-24 15:20:36 -04001427 }
1428}
1429
James Darpinian4d9d4832018-03-13 12:43:28 -07001430void State::detachBuffer(const Context *context, const Buffer *buffer)
Yuly Novikov5807a532015-12-03 13:01:22 -05001431{
James Darpinian4d9d4832018-03-13 12:43:28 -07001432 if (!buffer->isBound())
1433 {
1434 return;
1435 }
1436 GLuint bufferName = buffer->id();
James Darpiniane8a93c62018-01-04 18:02:24 -08001437 for (auto target : angle::AllEnums<BufferBinding>())
Yuly Novikov5807a532015-12-03 13:01:22 -05001438 {
James Darpiniane8a93c62018-01-04 18:02:24 -08001439 if (mBoundBuffers[target].id() == bufferName)
Yuly Novikov5807a532015-12-03 13:01:22 -05001440 {
James Darpiniane8a93c62018-01-04 18:02:24 -08001441 UpdateBufferBinding(context, &mBoundBuffers[target], nullptr, target);
Yuly Novikov5807a532015-12-03 13:01:22 -05001442 }
1443 }
1444
1445 TransformFeedback *curTransformFeedback = getCurrentTransformFeedback();
1446 if (curTransformFeedback)
1447 {
Jamie Madill4928b7c2017-06-20 12:57:39 -04001448 curTransformFeedback->detachBuffer(context, bufferName);
Yuly Novikov5807a532015-12-03 13:01:22 -05001449 }
1450
Jamie Madill4928b7c2017-06-20 12:57:39 -04001451 getVertexArray()->detachBuffer(context, bufferName);
James Darpiniane8a93c62018-01-04 18:02:24 -08001452
1453 for (auto &buf : mUniformBuffers)
1454 {
1455 if (buf.id() == bufferName)
1456 {
1457 UpdateBufferBinding(context, &buf, nullptr, BufferBinding::Uniform);
1458 }
1459 }
1460
1461 for (auto &buf : mAtomicCounterBuffers)
1462 {
1463 if (buf.id() == bufferName)
1464 {
1465 UpdateBufferBinding(context, &buf, nullptr, BufferBinding::AtomicCounter);
1466 }
1467 }
1468
1469 for (auto &buf : mShaderStorageBuffers)
1470 {
1471 if (buf.id() == bufferName)
1472 {
1473 UpdateBufferBinding(context, &buf, nullptr, BufferBinding::ShaderStorage);
1474 }
1475 }
Yuly Novikov5807a532015-12-03 13:01:22 -05001476}
1477
Shannon Woods53a94a82014-06-24 15:20:36 -04001478void State::setEnableVertexAttribArray(unsigned int attribNum, bool enabled)
1479{
1480 getVertexArray()->enableAttribute(attribNum, enabled);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001481 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001482}
1483
1484void State::setVertexAttribf(GLuint index, const GLfloat values[4])
1485{
Shannon Woods23e05002014-09-22 19:07:27 -04001486 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001487 mVertexAttribCurrentValues[index].setFloatValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001488 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1489 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001490 mCurrentValuesTypeMask.setIndex(GL_FLOAT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001491}
1492
1493void State::setVertexAttribu(GLuint index, const GLuint values[4])
1494{
Shannon Woods23e05002014-09-22 19:07:27 -04001495 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001496 mVertexAttribCurrentValues[index].setUnsignedIntValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001497 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1498 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001499 mCurrentValuesTypeMask.setIndex(GL_UNSIGNED_INT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001500}
1501
1502void State::setVertexAttribi(GLuint index, const GLint values[4])
1503{
Shannon Woods23e05002014-09-22 19:07:27 -04001504 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001505 mVertexAttribCurrentValues[index].setIntValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001506 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1507 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001508 mCurrentValuesTypeMask.setIndex(GL_INT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001509}
1510
Shaodde78e82017-05-22 14:13:27 +08001511void State::setVertexAttribPointer(const Context *context,
1512 unsigned int attribNum,
1513 Buffer *boundBuffer,
1514 GLint size,
1515 GLenum type,
1516 bool normalized,
1517 bool pureInteger,
1518 GLsizei stride,
1519 const void *pointer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001520{
Shaodde78e82017-05-22 14:13:27 +08001521 getVertexArray()->setVertexAttribPointer(context, attribNum, boundBuffer, size, type,
1522 normalized, pureInteger, stride, pointer);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001523 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Jamie Madill0b9e9032015-08-17 11:51:52 +00001524}
1525
Shaodde78e82017-05-22 14:13:27 +08001526void State::setVertexAttribDivisor(const Context *context, GLuint index, GLuint divisor)
Jamie Madill0b9e9032015-08-17 11:51:52 +00001527{
Shaodde78e82017-05-22 14:13:27 +08001528 getVertexArray()->setVertexAttribDivisor(context, index, divisor);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001529 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001530}
1531
Jamie Madill6de51852017-04-12 09:53:01 -04001532const VertexAttribCurrentValueData &State::getVertexAttribCurrentValue(size_t attribNum) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001533{
Jamie Madill6de51852017-04-12 09:53:01 -04001534 ASSERT(attribNum < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001535 return mVertexAttribCurrentValues[attribNum];
1536}
1537
Jamie Madillcac94a92017-11-10 10:09:32 -05001538const std::vector<VertexAttribCurrentValueData> &State::getVertexAttribCurrentValues() const
1539{
1540 return mVertexAttribCurrentValues;
1541}
1542
Shannon Woods53a94a82014-06-24 15:20:36 -04001543const void *State::getVertexAttribPointer(unsigned int attribNum) const
1544{
1545 return getVertexArray()->getVertexAttribute(attribNum).pointer;
1546}
1547
1548void State::setPackAlignment(GLint alignment)
1549{
1550 mPack.alignment = alignment;
Jamie Madillc67323a2017-11-02 23:11:41 -04001551 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001552}
1553
1554GLint State::getPackAlignment() const
1555{
1556 return mPack.alignment;
1557}
1558
1559void State::setPackReverseRowOrder(bool reverseRowOrder)
1560{
1561 mPack.reverseRowOrder = reverseRowOrder;
Jamie Madillc67323a2017-11-02 23:11:41 -04001562 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001563}
1564
1565bool State::getPackReverseRowOrder() const
1566{
1567 return mPack.reverseRowOrder;
1568}
1569
Minmin Gongadff67b2015-10-14 10:34:45 -04001570void State::setPackRowLength(GLint rowLength)
1571{
1572 mPack.rowLength = rowLength;
Jamie Madillc67323a2017-11-02 23:11:41 -04001573 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001574}
1575
1576GLint State::getPackRowLength() const
1577{
1578 return mPack.rowLength;
1579}
1580
1581void State::setPackSkipRows(GLint skipRows)
1582{
1583 mPack.skipRows = skipRows;
Jamie Madillc67323a2017-11-02 23:11:41 -04001584 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001585}
1586
1587GLint State::getPackSkipRows() const
1588{
1589 return mPack.skipRows;
1590}
1591
1592void State::setPackSkipPixels(GLint skipPixels)
1593{
1594 mPack.skipPixels = skipPixels;
Jamie Madillc67323a2017-11-02 23:11:41 -04001595 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001596}
1597
1598GLint State::getPackSkipPixels() const
1599{
1600 return mPack.skipPixels;
1601}
1602
Shannon Woods53a94a82014-06-24 15:20:36 -04001603const PixelPackState &State::getPackState() const
1604{
1605 return mPack;
1606}
1607
Jamie Madill87de3622015-03-16 10:41:44 -04001608PixelPackState &State::getPackState()
1609{
1610 return mPack;
1611}
1612
Shannon Woods53a94a82014-06-24 15:20:36 -04001613void State::setUnpackAlignment(GLint alignment)
1614{
1615 mUnpack.alignment = alignment;
Jamie Madillc67323a2017-11-02 23:11:41 -04001616 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001617}
1618
1619GLint State::getUnpackAlignment() const
1620{
1621 return mUnpack.alignment;
1622}
1623
Minmin Gongb8aee3b2015-01-27 14:42:36 -08001624void State::setUnpackRowLength(GLint rowLength)
1625{
1626 mUnpack.rowLength = rowLength;
Jamie Madillc67323a2017-11-02 23:11:41 -04001627 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongb8aee3b2015-01-27 14:42:36 -08001628}
1629
1630GLint State::getUnpackRowLength() const
1631{
1632 return mUnpack.rowLength;
1633}
1634
Minmin Gongadff67b2015-10-14 10:34:45 -04001635void State::setUnpackImageHeight(GLint imageHeight)
1636{
1637 mUnpack.imageHeight = imageHeight;
Jamie Madillc67323a2017-11-02 23:11:41 -04001638 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001639}
1640
1641GLint State::getUnpackImageHeight() const
1642{
1643 return mUnpack.imageHeight;
1644}
1645
1646void State::setUnpackSkipImages(GLint skipImages)
1647{
1648 mUnpack.skipImages = skipImages;
Jamie Madillc67323a2017-11-02 23:11:41 -04001649 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001650}
1651
1652GLint State::getUnpackSkipImages() const
1653{
1654 return mUnpack.skipImages;
1655}
1656
1657void State::setUnpackSkipRows(GLint skipRows)
1658{
1659 mUnpack.skipRows = skipRows;
Jamie Madillc67323a2017-11-02 23:11:41 -04001660 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001661}
1662
1663GLint State::getUnpackSkipRows() const
1664{
1665 return mUnpack.skipRows;
1666}
1667
1668void State::setUnpackSkipPixels(GLint skipPixels)
1669{
1670 mUnpack.skipPixels = skipPixels;
Jamie Madillc67323a2017-11-02 23:11:41 -04001671 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001672}
1673
1674GLint State::getUnpackSkipPixels() const
1675{
1676 return mUnpack.skipPixels;
1677}
1678
Shannon Woods53a94a82014-06-24 15:20:36 -04001679const PixelUnpackState &State::getUnpackState() const
1680{
1681 return mUnpack;
1682}
1683
Jamie Madill67102f02015-03-16 10:41:42 -04001684PixelUnpackState &State::getUnpackState()
1685{
1686 return mUnpack;
1687}
1688
Geoff Lang70d0f492015-12-10 17:45:46 -05001689const Debug &State::getDebug() const
1690{
1691 return mDebug;
1692}
1693
1694Debug &State::getDebug()
1695{
1696 return mDebug;
1697}
1698
Sami Väisänena797e062016-05-12 15:23:40 +03001699void State::setCoverageModulation(GLenum components)
1700{
1701 mCoverageModulation = components;
1702 mDirtyBits.set(DIRTY_BIT_COVERAGE_MODULATION);
1703}
1704
1705GLenum State::getCoverageModulation() const
1706{
1707 return mCoverageModulation;
1708}
1709
Sami Väisänene45e53b2016-05-25 10:36:04 +03001710void State::loadPathRenderingMatrix(GLenum matrixMode, const GLfloat *matrix)
1711{
1712 if (matrixMode == GL_PATH_MODELVIEW_CHROMIUM)
1713 {
1714 memcpy(mPathMatrixMV, matrix, 16 * sizeof(GLfloat));
1715 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING_MATRIX_MV);
1716 }
1717 else if (matrixMode == GL_PATH_PROJECTION_CHROMIUM)
1718 {
1719 memcpy(mPathMatrixProj, matrix, 16 * sizeof(GLfloat));
1720 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING_MATRIX_PROJ);
1721 }
1722 else
1723 {
1724 UNREACHABLE();
1725 }
1726}
1727
1728const GLfloat *State::getPathRenderingMatrix(GLenum which) const
1729{
1730 if (which == GL_PATH_MODELVIEW_MATRIX_CHROMIUM)
1731 {
1732 return mPathMatrixMV;
1733 }
1734 else if (which == GL_PATH_PROJECTION_MATRIX_CHROMIUM)
1735 {
1736 return mPathMatrixProj;
1737 }
1738
1739 UNREACHABLE();
1740 return nullptr;
1741}
1742
1743void State::setPathStencilFunc(GLenum func, GLint ref, GLuint mask)
1744{
1745 mPathStencilFunc = func;
1746 mPathStencilRef = ref;
1747 mPathStencilMask = mask;
1748 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING_STENCIL_STATE);
1749}
1750
1751GLenum State::getPathStencilFunc() const
1752{
1753 return mPathStencilFunc;
1754}
1755
1756GLint State::getPathStencilRef() const
1757{
1758 return mPathStencilRef;
1759}
1760
1761GLuint State::getPathStencilMask() const
1762{
1763 return mPathStencilMask;
1764}
1765
Geoff Lang1d2c41d2016-10-19 16:14:46 -07001766void State::setFramebufferSRGB(bool sRGB)
1767{
1768 mFramebufferSRGB = sRGB;
1769 mDirtyBits.set(DIRTY_BIT_FRAMEBUFFER_SRGB);
1770}
1771
1772bool State::getFramebufferSRGB() const
1773{
1774 return mFramebufferSRGB;
1775}
1776
Shannon Woods53a94a82014-06-24 15:20:36 -04001777void State::getBooleanv(GLenum pname, GLboolean *params)
1778{
1779 switch (pname)
1780 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001781 case GL_SAMPLE_COVERAGE_INVERT:
1782 *params = mSampleCoverageInvert;
1783 break;
1784 case GL_DEPTH_WRITEMASK:
1785 *params = mDepthStencil.depthMask;
1786 break;
1787 case GL_COLOR_WRITEMASK:
1788 params[0] = mBlend.colorMaskRed;
1789 params[1] = mBlend.colorMaskGreen;
1790 params[2] = mBlend.colorMaskBlue;
1791 params[3] = mBlend.colorMaskAlpha;
1792 break;
1793 case GL_CULL_FACE:
1794 *params = mRasterizer.cullFace;
1795 break;
1796 case GL_POLYGON_OFFSET_FILL:
1797 *params = mRasterizer.polygonOffsetFill;
1798 break;
1799 case GL_SAMPLE_ALPHA_TO_COVERAGE:
1800 *params = mBlend.sampleAlphaToCoverage;
1801 break;
1802 case GL_SAMPLE_COVERAGE:
1803 *params = mSampleCoverage;
1804 break;
1805 case GL_SAMPLE_MASK:
1806 *params = mSampleMask;
1807 break;
1808 case GL_SCISSOR_TEST:
1809 *params = mScissorTest;
1810 break;
1811 case GL_STENCIL_TEST:
1812 *params = mDepthStencil.stencilTest;
1813 break;
1814 case GL_DEPTH_TEST:
1815 *params = mDepthStencil.depthTest;
1816 break;
1817 case GL_BLEND:
1818 *params = mBlend.blend;
1819 break;
1820 case GL_DITHER:
1821 *params = mBlend.dither;
1822 break;
1823 case GL_TRANSFORM_FEEDBACK_ACTIVE:
1824 *params = getCurrentTransformFeedback()->isActive() ? GL_TRUE : GL_FALSE;
1825 break;
1826 case GL_TRANSFORM_FEEDBACK_PAUSED:
1827 *params = getCurrentTransformFeedback()->isPaused() ? GL_TRUE : GL_FALSE;
1828 break;
1829 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
1830 *params = mPrimitiveRestart;
1831 break;
1832 case GL_RASTERIZER_DISCARD:
1833 *params = isRasterizerDiscardEnabled() ? GL_TRUE : GL_FALSE;
1834 break;
1835 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
1836 *params = mDebug.isOutputSynchronous() ? GL_TRUE : GL_FALSE;
1837 break;
1838 case GL_DEBUG_OUTPUT:
1839 *params = mDebug.isOutputEnabled() ? GL_TRUE : GL_FALSE;
1840 break;
1841 case GL_MULTISAMPLE_EXT:
1842 *params = mMultiSampling;
1843 break;
1844 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
1845 *params = mSampleAlphaToOne;
1846 break;
1847 case GL_BIND_GENERATES_RESOURCE_CHROMIUM:
1848 *params = isBindGeneratesResourceEnabled() ? GL_TRUE : GL_FALSE;
1849 break;
1850 case GL_CLIENT_ARRAYS_ANGLE:
1851 *params = areClientArraysEnabled() ? GL_TRUE : GL_FALSE;
1852 break;
1853 case GL_FRAMEBUFFER_SRGB_EXT:
1854 *params = getFramebufferSRGB() ? GL_TRUE : GL_FALSE;
1855 break;
1856 case GL_ROBUST_RESOURCE_INITIALIZATION_ANGLE:
1857 *params = mRobustResourceInit ? GL_TRUE : GL_FALSE;
1858 break;
1859 case GL_PROGRAM_CACHE_ENABLED_ANGLE:
1860 *params = mProgramBinaryCacheEnabled ? GL_TRUE : GL_FALSE;
1861 break;
Jamie Madillc43be722017-07-13 16:22:14 -04001862
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001863 default:
1864 UNREACHABLE();
1865 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04001866 }
1867}
1868
1869void State::getFloatv(GLenum pname, GLfloat *params)
1870{
1871 // Please note: DEPTH_CLEAR_VALUE is included in our internal getFloatv implementation
1872 // because it is stored as a float, despite the fact that the GL ES 2.0 spec names
1873 // GetIntegerv as its native query function. As it would require conversion in any
1874 // case, this should make no difference to the calling application.
1875 switch (pname)
1876 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001877 case GL_LINE_WIDTH:
1878 *params = mLineWidth;
1879 break;
1880 case GL_SAMPLE_COVERAGE_VALUE:
1881 *params = mSampleCoverageValue;
1882 break;
1883 case GL_DEPTH_CLEAR_VALUE:
1884 *params = mDepthClearValue;
1885 break;
1886 case GL_POLYGON_OFFSET_FACTOR:
1887 *params = mRasterizer.polygonOffsetFactor;
1888 break;
1889 case GL_POLYGON_OFFSET_UNITS:
1890 *params = mRasterizer.polygonOffsetUnits;
1891 break;
1892 case GL_DEPTH_RANGE:
1893 params[0] = mNearZ;
1894 params[1] = mFarZ;
1895 break;
1896 case GL_COLOR_CLEAR_VALUE:
1897 params[0] = mColorClearValue.red;
1898 params[1] = mColorClearValue.green;
1899 params[2] = mColorClearValue.blue;
1900 params[3] = mColorClearValue.alpha;
1901 break;
1902 case GL_BLEND_COLOR:
1903 params[0] = mBlendColor.red;
1904 params[1] = mBlendColor.green;
1905 params[2] = mBlendColor.blue;
1906 params[3] = mBlendColor.alpha;
1907 break;
1908 case GL_MULTISAMPLE_EXT:
1909 *params = static_cast<GLfloat>(mMultiSampling);
1910 break;
1911 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
1912 *params = static_cast<GLfloat>(mSampleAlphaToOne);
1913 break;
1914 case GL_COVERAGE_MODULATION_CHROMIUM:
1915 params[0] = static_cast<GLfloat>(mCoverageModulation);
1916 break;
1917 default:
1918 UNREACHABLE();
1919 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04001920 }
1921}
1922
Jamie Madille98b1b52018-03-08 09:47:23 -05001923Error State::getIntegerv(const Context *context, GLenum pname, GLint *params)
Shannon Woods53a94a82014-06-24 15:20:36 -04001924{
1925 if (pname >= GL_DRAW_BUFFER0_EXT && pname <= GL_DRAW_BUFFER15_EXT)
1926 {
1927 unsigned int colorAttachment = (pname - GL_DRAW_BUFFER0_EXT);
Shannon Woods2df6a602014-09-26 16:12:07 -04001928 ASSERT(colorAttachment < mMaxDrawBuffers);
Shannon Woods53a94a82014-06-24 15:20:36 -04001929 Framebuffer *framebuffer = mDrawFramebuffer;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001930 *params = framebuffer->getDrawBufferState(colorAttachment);
Jamie Madille98b1b52018-03-08 09:47:23 -05001931 return NoError();
Shannon Woods53a94a82014-06-24 15:20:36 -04001932 }
1933
1934 // Please note: DEPTH_CLEAR_VALUE is not included in our internal getIntegerv implementation
1935 // because it is stored as a float, despite the fact that the GL ES 2.0 spec names
1936 // GetIntegerv as its native query function. As it would require conversion in any
1937 // case, this should make no difference to the calling application. You may find it in
1938 // State::getFloatv.
1939 switch (pname)
1940 {
Corentin Wallez336129f2017-10-17 15:55:40 -04001941 case GL_ARRAY_BUFFER_BINDING:
1942 *params = mBoundBuffers[BufferBinding::Array].id();
1943 break;
1944 case GL_DRAW_INDIRECT_BUFFER_BINDING:
1945 *params = mBoundBuffers[BufferBinding::DrawIndirect].id();
1946 break;
1947 case GL_ELEMENT_ARRAY_BUFFER_BINDING:
1948 *params = getVertexArray()->getElementArrayBuffer().id();
1949 break;
Jamie Madill690c8eb2018-03-12 15:20:03 -04001950 case GL_DRAW_FRAMEBUFFER_BINDING:
1951 static_assert(GL_DRAW_FRAMEBUFFER_BINDING == GL_DRAW_FRAMEBUFFER_BINDING_ANGLE,
1952 "Enum mismatch");
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001953 *params = mDrawFramebuffer->id();
1954 break;
Jamie Madill690c8eb2018-03-12 15:20:03 -04001955 case GL_READ_FRAMEBUFFER_BINDING:
1956 static_assert(GL_READ_FRAMEBUFFER_BINDING == GL_READ_FRAMEBUFFER_BINDING_ANGLE,
1957 "Enum mismatch");
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001958 *params = mReadFramebuffer->id();
1959 break;
1960 case GL_RENDERBUFFER_BINDING:
1961 *params = mRenderbuffer.id();
1962 break;
1963 case GL_VERTEX_ARRAY_BINDING:
1964 *params = mVertexArray->id();
1965 break;
1966 case GL_CURRENT_PROGRAM:
1967 *params = mProgram ? mProgram->id() : 0;
1968 break;
1969 case GL_PACK_ALIGNMENT:
1970 *params = mPack.alignment;
1971 break;
1972 case GL_PACK_REVERSE_ROW_ORDER_ANGLE:
1973 *params = mPack.reverseRowOrder;
1974 break;
1975 case GL_PACK_ROW_LENGTH:
1976 *params = mPack.rowLength;
1977 break;
1978 case GL_PACK_SKIP_ROWS:
1979 *params = mPack.skipRows;
1980 break;
1981 case GL_PACK_SKIP_PIXELS:
1982 *params = mPack.skipPixels;
1983 break;
1984 case GL_UNPACK_ALIGNMENT:
1985 *params = mUnpack.alignment;
1986 break;
1987 case GL_UNPACK_ROW_LENGTH:
1988 *params = mUnpack.rowLength;
1989 break;
1990 case GL_UNPACK_IMAGE_HEIGHT:
1991 *params = mUnpack.imageHeight;
1992 break;
1993 case GL_UNPACK_SKIP_IMAGES:
1994 *params = mUnpack.skipImages;
1995 break;
1996 case GL_UNPACK_SKIP_ROWS:
1997 *params = mUnpack.skipRows;
1998 break;
1999 case GL_UNPACK_SKIP_PIXELS:
2000 *params = mUnpack.skipPixels;
2001 break;
2002 case GL_GENERATE_MIPMAP_HINT:
2003 *params = mGenerateMipmapHint;
2004 break;
2005 case GL_FRAGMENT_SHADER_DERIVATIVE_HINT_OES:
2006 *params = mFragmentShaderDerivativeHint;
2007 break;
2008 case GL_ACTIVE_TEXTURE:
2009 *params = (static_cast<GLint>(mActiveSampler) + GL_TEXTURE0);
2010 break;
2011 case GL_STENCIL_FUNC:
2012 *params = mDepthStencil.stencilFunc;
2013 break;
2014 case GL_STENCIL_REF:
2015 *params = mStencilRef;
2016 break;
2017 case GL_STENCIL_VALUE_MASK:
2018 *params = CastMaskValue(context, mDepthStencil.stencilMask);
2019 break;
2020 case GL_STENCIL_BACK_FUNC:
2021 *params = mDepthStencil.stencilBackFunc;
2022 break;
2023 case GL_STENCIL_BACK_REF:
2024 *params = mStencilBackRef;
2025 break;
2026 case GL_STENCIL_BACK_VALUE_MASK:
2027 *params = CastMaskValue(context, mDepthStencil.stencilBackMask);
2028 break;
2029 case GL_STENCIL_FAIL:
2030 *params = mDepthStencil.stencilFail;
2031 break;
2032 case GL_STENCIL_PASS_DEPTH_FAIL:
2033 *params = mDepthStencil.stencilPassDepthFail;
2034 break;
2035 case GL_STENCIL_PASS_DEPTH_PASS:
2036 *params = mDepthStencil.stencilPassDepthPass;
2037 break;
2038 case GL_STENCIL_BACK_FAIL:
2039 *params = mDepthStencil.stencilBackFail;
2040 break;
2041 case GL_STENCIL_BACK_PASS_DEPTH_FAIL:
2042 *params = mDepthStencil.stencilBackPassDepthFail;
2043 break;
2044 case GL_STENCIL_BACK_PASS_DEPTH_PASS:
2045 *params = mDepthStencil.stencilBackPassDepthPass;
2046 break;
2047 case GL_DEPTH_FUNC:
2048 *params = mDepthStencil.depthFunc;
2049 break;
2050 case GL_BLEND_SRC_RGB:
2051 *params = mBlend.sourceBlendRGB;
2052 break;
2053 case GL_BLEND_SRC_ALPHA:
2054 *params = mBlend.sourceBlendAlpha;
2055 break;
2056 case GL_BLEND_DST_RGB:
2057 *params = mBlend.destBlendRGB;
2058 break;
2059 case GL_BLEND_DST_ALPHA:
2060 *params = mBlend.destBlendAlpha;
2061 break;
2062 case GL_BLEND_EQUATION_RGB:
2063 *params = mBlend.blendEquationRGB;
2064 break;
2065 case GL_BLEND_EQUATION_ALPHA:
2066 *params = mBlend.blendEquationAlpha;
2067 break;
2068 case GL_STENCIL_WRITEMASK:
2069 *params = CastMaskValue(context, mDepthStencil.stencilWritemask);
2070 break;
2071 case GL_STENCIL_BACK_WRITEMASK:
2072 *params = CastMaskValue(context, mDepthStencil.stencilBackWritemask);
2073 break;
2074 case GL_STENCIL_CLEAR_VALUE:
2075 *params = mStencilClearValue;
2076 break;
2077 case GL_IMPLEMENTATION_COLOR_READ_TYPE:
Jamie Madill690c8eb2018-03-12 15:20:03 -04002078 ANGLE_TRY(mReadFramebuffer->getImplementationColorReadType(
2079 context, reinterpret_cast<GLenum *>(params)));
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002080 break;
2081 case GL_IMPLEMENTATION_COLOR_READ_FORMAT:
Jamie Madill690c8eb2018-03-12 15:20:03 -04002082 ANGLE_TRY(mReadFramebuffer->getImplementationColorReadFormat(
2083 context, reinterpret_cast<GLenum *>(params)));
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002084 break;
2085 case GL_SAMPLE_BUFFERS:
2086 case GL_SAMPLES:
Shannon Woods53a94a82014-06-24 15:20:36 -04002087 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002088 Framebuffer *framebuffer = mDrawFramebuffer;
Jamie Madille98b1b52018-03-08 09:47:23 -05002089 bool complete = false;
2090 ANGLE_TRY(framebuffer->isComplete(context, &complete));
2091 if (complete)
Shannon Woods53a94a82014-06-24 15:20:36 -04002092 {
Jamie Madille98b1b52018-03-08 09:47:23 -05002093 GLint samples = 0;
2094 ANGLE_TRY(framebuffer->getSamples(context, &samples));
Shannon Woods53a94a82014-06-24 15:20:36 -04002095 switch (pname)
2096 {
Jamie Madilla0016b72017-07-14 14:30:46 -04002097 case GL_SAMPLE_BUFFERS:
Jamie Madille98b1b52018-03-08 09:47:23 -05002098 if (samples != 0)
Jamie Madilla0016b72017-07-14 14:30:46 -04002099 {
2100 *params = 1;
2101 }
2102 else
2103 {
2104 *params = 0;
2105 }
2106 break;
2107 case GL_SAMPLES:
Jamie Madille98b1b52018-03-08 09:47:23 -05002108 *params = samples;
Jamie Madilla0016b72017-07-14 14:30:46 -04002109 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002110 }
2111 }
2112 else
2113 {
2114 *params = 0;
2115 }
2116 }
2117 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002118 case GL_VIEWPORT:
2119 params[0] = mViewport.x;
2120 params[1] = mViewport.y;
2121 params[2] = mViewport.width;
2122 params[3] = mViewport.height;
2123 break;
2124 case GL_SCISSOR_BOX:
2125 params[0] = mScissor.x;
2126 params[1] = mScissor.y;
2127 params[2] = mScissor.width;
2128 params[3] = mScissor.height;
2129 break;
2130 case GL_CULL_FACE_MODE:
2131 *params = ToGLenum(mRasterizer.cullMode);
2132 break;
2133 case GL_FRONT_FACE:
2134 *params = mRasterizer.frontFace;
2135 break;
2136 case GL_RED_BITS:
2137 case GL_GREEN_BITS:
2138 case GL_BLUE_BITS:
2139 case GL_ALPHA_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002140 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002141 Framebuffer *framebuffer = getDrawFramebuffer();
2142 const FramebufferAttachment *colorbuffer = framebuffer->getFirstColorbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002143
2144 if (colorbuffer)
2145 {
2146 switch (pname)
2147 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002148 case GL_RED_BITS:
2149 *params = colorbuffer->getRedSize();
2150 break;
2151 case GL_GREEN_BITS:
2152 *params = colorbuffer->getGreenSize();
2153 break;
2154 case GL_BLUE_BITS:
2155 *params = colorbuffer->getBlueSize();
2156 break;
2157 case GL_ALPHA_BITS:
2158 *params = colorbuffer->getAlphaSize();
2159 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002160 }
2161 }
2162 else
2163 {
2164 *params = 0;
2165 }
2166 }
2167 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002168 case GL_DEPTH_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002169 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002170 const Framebuffer *framebuffer = getDrawFramebuffer();
2171 const FramebufferAttachment *depthbuffer = framebuffer->getDepthbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002172
2173 if (depthbuffer)
2174 {
2175 *params = depthbuffer->getDepthSize();
2176 }
2177 else
2178 {
2179 *params = 0;
2180 }
2181 }
2182 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002183 case GL_STENCIL_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002184 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002185 const Framebuffer *framebuffer = getDrawFramebuffer();
2186 const FramebufferAttachment *stencilbuffer = framebuffer->getStencilbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002187
2188 if (stencilbuffer)
2189 {
2190 *params = stencilbuffer->getStencilSize();
2191 }
2192 else
2193 {
2194 *params = 0;
2195 }
2196 }
2197 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002198 case GL_TEXTURE_BINDING_2D:
2199 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2200 *params =
2201 getSamplerTextureId(static_cast<unsigned int>(mActiveSampler), TextureType::_2D);
2202 break;
2203 case GL_TEXTURE_BINDING_RECTANGLE_ANGLE:
2204 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2205 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2206 TextureType::Rectangle);
2207 break;
2208 case GL_TEXTURE_BINDING_CUBE_MAP:
2209 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2210 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2211 TextureType::CubeMap);
2212 break;
2213 case GL_TEXTURE_BINDING_3D:
2214 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2215 *params =
2216 getSamplerTextureId(static_cast<unsigned int>(mActiveSampler), TextureType::_3D);
2217 break;
2218 case GL_TEXTURE_BINDING_2D_ARRAY:
2219 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2220 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2221 TextureType::_2DArray);
2222 break;
2223 case GL_TEXTURE_BINDING_2D_MULTISAMPLE:
2224 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2225 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2226 TextureType::_2DMultisample);
2227 break;
2228 case GL_TEXTURE_BINDING_EXTERNAL_OES:
2229 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2230 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2231 TextureType::External);
2232 break;
2233 case GL_UNIFORM_BUFFER_BINDING:
2234 *params = mBoundBuffers[BufferBinding::Uniform].id();
2235 break;
2236 case GL_TRANSFORM_FEEDBACK_BINDING:
2237 *params = mTransformFeedback.id();
2238 break;
2239 case GL_TRANSFORM_FEEDBACK_BUFFER_BINDING:
2240 *params = mBoundBuffers[BufferBinding::TransformFeedback].id();
2241 break;
2242 case GL_COPY_READ_BUFFER_BINDING:
2243 *params = mBoundBuffers[BufferBinding::CopyRead].id();
2244 break;
2245 case GL_COPY_WRITE_BUFFER_BINDING:
2246 *params = mBoundBuffers[BufferBinding::CopyWrite].id();
2247 break;
2248 case GL_PIXEL_PACK_BUFFER_BINDING:
2249 *params = mBoundBuffers[BufferBinding::PixelPack].id();
2250 break;
2251 case GL_PIXEL_UNPACK_BUFFER_BINDING:
2252 *params = mBoundBuffers[BufferBinding::PixelUnpack].id();
2253 break;
2254 case GL_READ_BUFFER:
2255 *params = mReadFramebuffer->getReadBufferState();
2256 break;
2257 case GL_SAMPLER_BINDING:
2258 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2259 *params = getSamplerId(static_cast<GLuint>(mActiveSampler));
2260 break;
2261 case GL_DEBUG_LOGGED_MESSAGES:
2262 *params = static_cast<GLint>(mDebug.getMessageCount());
2263 break;
2264 case GL_DEBUG_NEXT_LOGGED_MESSAGE_LENGTH:
2265 *params = static_cast<GLint>(mDebug.getNextMessageLength());
2266 break;
2267 case GL_DEBUG_GROUP_STACK_DEPTH:
2268 *params = static_cast<GLint>(mDebug.getGroupStackDepth());
2269 break;
2270 case GL_MULTISAMPLE_EXT:
2271 *params = static_cast<GLint>(mMultiSampling);
2272 break;
2273 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
2274 *params = static_cast<GLint>(mSampleAlphaToOne);
2275 break;
2276 case GL_COVERAGE_MODULATION_CHROMIUM:
2277 *params = static_cast<GLint>(mCoverageModulation);
2278 break;
2279 case GL_ATOMIC_COUNTER_BUFFER_BINDING:
2280 *params = mBoundBuffers[BufferBinding::AtomicCounter].id();
2281 break;
2282 case GL_SHADER_STORAGE_BUFFER_BINDING:
2283 *params = mBoundBuffers[BufferBinding::ShaderStorage].id();
2284 break;
2285 case GL_DISPATCH_INDIRECT_BUFFER_BINDING:
2286 *params = mBoundBuffers[BufferBinding::DispatchIndirect].id();
2287 break;
2288 default:
2289 UNREACHABLE();
2290 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002291 }
Jamie Madille98b1b52018-03-08 09:47:23 -05002292
2293 return NoError();
Shannon Woods53a94a82014-06-24 15:20:36 -04002294}
2295
Geoff Lang70d0f492015-12-10 17:45:46 -05002296void State::getPointerv(GLenum pname, void **params) const
2297{
2298 switch (pname)
2299 {
2300 case GL_DEBUG_CALLBACK_FUNCTION:
2301 *params = reinterpret_cast<void *>(mDebug.getCallback());
2302 break;
2303 case GL_DEBUG_CALLBACK_USER_PARAM:
2304 *params = const_cast<void *>(mDebug.getUserParam());
2305 break;
2306 default:
2307 UNREACHABLE();
2308 break;
2309 }
2310}
2311
Martin Radev66fb8202016-07-28 11:45:20 +03002312void State::getIntegeri_v(GLenum target, GLuint index, GLint *data)
Shannon Woods53a94a82014-06-24 15:20:36 -04002313{
2314 switch (target)
2315 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002316 case GL_TRANSFORM_FEEDBACK_BUFFER_BINDING:
2317 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2318 *data = mTransformFeedback->getIndexedBuffer(index).id();
2319 break;
2320 case GL_UNIFORM_BUFFER_BINDING:
2321 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2322 *data = mUniformBuffers[index].id();
2323 break;
2324 case GL_ATOMIC_COUNTER_BUFFER_BINDING:
2325 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2326 *data = mAtomicCounterBuffers[index].id();
2327 break;
2328 case GL_SHADER_STORAGE_BUFFER_BINDING:
2329 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2330 *data = mShaderStorageBuffers[index].id();
2331 break;
2332 case GL_VERTEX_BINDING_BUFFER:
2333 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2334 *data = mVertexArray->getVertexBinding(index).getBuffer().id();
2335 break;
2336 case GL_VERTEX_BINDING_DIVISOR:
2337 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2338 *data = mVertexArray->getVertexBinding(index).getDivisor();
2339 break;
2340 case GL_VERTEX_BINDING_OFFSET:
2341 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2342 *data = static_cast<GLuint>(mVertexArray->getVertexBinding(index).getOffset());
2343 break;
2344 case GL_VERTEX_BINDING_STRIDE:
2345 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2346 *data = mVertexArray->getVertexBinding(index).getStride();
2347 break;
2348 case GL_SAMPLE_MASK_VALUE:
2349 ASSERT(static_cast<size_t>(index) < mSampleMaskValues.size());
2350 *data = mSampleMaskValues[index];
2351 break;
2352 case GL_IMAGE_BINDING_NAME:
2353 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2354 *data = mImageUnits[index].texture.id();
2355 break;
2356 case GL_IMAGE_BINDING_LEVEL:
2357 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2358 *data = mImageUnits[index].level;
2359 break;
2360 case GL_IMAGE_BINDING_LAYER:
2361 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2362 *data = mImageUnits[index].layer;
2363 break;
2364 case GL_IMAGE_BINDING_ACCESS:
2365 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2366 *data = mImageUnits[index].access;
2367 break;
2368 case GL_IMAGE_BINDING_FORMAT:
2369 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2370 *data = mImageUnits[index].format;
2371 break;
2372 default:
2373 UNREACHABLE();
2374 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002375 }
Shannon Woods53a94a82014-06-24 15:20:36 -04002376}
2377
Martin Radev66fb8202016-07-28 11:45:20 +03002378void State::getInteger64i_v(GLenum target, GLuint index, GLint64 *data)
Shannon Woods53a94a82014-06-24 15:20:36 -04002379{
2380 switch (target)
2381 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002382 case GL_TRANSFORM_FEEDBACK_BUFFER_START:
2383 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2384 *data = mTransformFeedback->getIndexedBuffer(index).getOffset();
2385 break;
2386 case GL_TRANSFORM_FEEDBACK_BUFFER_SIZE:
2387 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2388 *data = mTransformFeedback->getIndexedBuffer(index).getSize();
2389 break;
2390 case GL_UNIFORM_BUFFER_START:
2391 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2392 *data = mUniformBuffers[index].getOffset();
2393 break;
2394 case GL_UNIFORM_BUFFER_SIZE:
2395 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2396 *data = mUniformBuffers[index].getSize();
2397 break;
2398 case GL_ATOMIC_COUNTER_BUFFER_START:
2399 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2400 *data = mAtomicCounterBuffers[index].getOffset();
2401 break;
2402 case GL_ATOMIC_COUNTER_BUFFER_SIZE:
2403 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2404 *data = mAtomicCounterBuffers[index].getSize();
2405 break;
2406 case GL_SHADER_STORAGE_BUFFER_START:
2407 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2408 *data = mShaderStorageBuffers[index].getOffset();
2409 break;
2410 case GL_SHADER_STORAGE_BUFFER_SIZE:
2411 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2412 *data = mShaderStorageBuffers[index].getSize();
2413 break;
2414 default:
2415 UNREACHABLE();
2416 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002417 }
Martin Radev66fb8202016-07-28 11:45:20 +03002418}
Shannon Woods53a94a82014-06-24 15:20:36 -04002419
Martin Radev66fb8202016-07-28 11:45:20 +03002420void State::getBooleani_v(GLenum target, GLuint index, GLboolean *data)
2421{
Xinghua Cao9c8e1a32017-12-06 17:59:58 +08002422 switch (target)
2423 {
2424 case GL_IMAGE_BINDING_LAYERED:
2425 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2426 *data = mImageUnits[index].layered;
2427 break;
2428 default:
2429 UNREACHABLE();
2430 break;
2431 }
Shannon Woods53a94a82014-06-24 15:20:36 -04002432}
2433
Corentin Wallez336129f2017-10-17 15:55:40 -04002434bool State::hasMappedBuffer(BufferBinding target) const
Jamie Madilld9ba4f72014-08-04 10:47:59 -04002435{
Corentin Wallez336129f2017-10-17 15:55:40 -04002436 if (target == BufferBinding::Array)
Jamie Madilld9ba4f72014-08-04 10:47:59 -04002437 {
Jiawei-Shao2597fb62016-12-09 16:38:02 +08002438 const VertexArray *vao = getVertexArray();
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002439 const auto &vertexAttribs = vao->getVertexAttributes();
Jiawei-Shao2597fb62016-12-09 16:38:02 +08002440 const auto &vertexBindings = vao->getVertexBindings();
Jamie Madilld078c682018-01-02 11:50:24 -05002441 for (size_t attribIndex : vao->getEnabledAttributesMask())
Jamie Madilld9ba4f72014-08-04 10:47:59 -04002442 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002443 const VertexAttribute &vertexAttrib = vertexAttribs[attribIndex];
Martin Radevdd5f27e2017-06-07 10:17:09 +03002444 auto *boundBuffer = vertexBindings[vertexAttrib.bindingIndex].getBuffer().get();
Jamie Madilld9ba4f72014-08-04 10:47:59 -04002445 if (vertexAttrib.enabled && boundBuffer && boundBuffer->isMapped())
2446 {
2447 return true;
2448 }
2449 }
2450
2451 return false;
2452 }
2453 else
2454 {
2455 Buffer *buffer = getTargetBuffer(target);
2456 return (buffer && buffer->isMapped());
2457 }
2458}
2459
Jamie Madillbc918e72018-03-08 09:47:21 -05002460Error State::syncDirtyObjects(const Context *context)
Jamie Madillc9d442d2016-01-20 11:17:24 -05002461{
2462 if (!mDirtyObjects.any())
Jamie Madillbc918e72018-03-08 09:47:21 -05002463 return NoError();
Jamie Madillc9d442d2016-01-20 11:17:24 -05002464
Jamie Madillbc918e72018-03-08 09:47:21 -05002465 return syncDirtyObjects(context, mDirtyObjects);
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002466}
2467
Jamie Madillbc918e72018-03-08 09:47:21 -05002468Error State::syncDirtyObjects(const Context *context, const DirtyObjects &bitset)
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002469{
Jiajia Qin5ae6ee42018-03-06 17:39:42 +08002470 const DirtyObjects &dirtyObjects = mDirtyObjects & bitset;
2471 for (auto dirtyObject : dirtyObjects)
Jamie Madillc9d442d2016-01-20 11:17:24 -05002472 {
2473 switch (dirtyObject)
2474 {
2475 case DIRTY_OBJECT_READ_FRAMEBUFFER:
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002476 ASSERT(mReadFramebuffer);
Jamie Madill19fa1c62018-03-08 09:47:21 -05002477 ANGLE_TRY(mReadFramebuffer->syncState(context));
Jamie Madillc9d442d2016-01-20 11:17:24 -05002478 break;
2479 case DIRTY_OBJECT_DRAW_FRAMEBUFFER:
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002480 ASSERT(mDrawFramebuffer);
Jamie Madill19fa1c62018-03-08 09:47:21 -05002481 ANGLE_TRY(mDrawFramebuffer->syncState(context));
Jamie Madillc9d442d2016-01-20 11:17:24 -05002482 break;
2483 case DIRTY_OBJECT_VERTEX_ARRAY:
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002484 ASSERT(mVertexArray);
Jamie Madill06ef36b2017-09-09 23:32:46 -04002485 mVertexArray->syncState(context);
Jamie Madillc9d442d2016-01-20 11:17:24 -05002486 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002487 case DIRTY_OBJECT_PROGRAM_TEXTURES:
2488 syncProgramTextures(context);
2489 break;
2490
Jamie Madillc9d442d2016-01-20 11:17:24 -05002491 default:
2492 UNREACHABLE();
2493 break;
2494 }
2495 }
2496
Jiajia Qin5ae6ee42018-03-06 17:39:42 +08002497 mDirtyObjects &= ~dirtyObjects;
Jamie Madillbc918e72018-03-08 09:47:21 -05002498 return NoError();
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002499}
2500
Jamie Madill81c2e252017-09-09 23:32:46 -04002501void State::syncProgramTextures(const Context *context)
2502{
Jamie Madill81c2e252017-09-09 23:32:46 -04002503 // TODO(jmadill): Fine-grained updates.
2504 if (!mProgram)
2505 {
2506 return;
2507 }
2508
2509 ASSERT(mDirtyObjects[DIRTY_OBJECT_PROGRAM_TEXTURES]);
2510 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
2511
Jamie Madill0f80ed82017-09-19 00:24:56 -04002512 ActiveTextureMask newActiveTextures;
2513
Geoff Lange51ba632017-11-21 11:45:25 -05002514 // Initialize to the 'Initialized' state and set to 'MayNeedInit' if any texture is not
2515 // initialized.
2516 mCachedTexturesInitState = InitState::Initialized;
2517
Jamie Madill81c2e252017-09-09 23:32:46 -04002518 for (const SamplerBinding &samplerBinding : mProgram->getSamplerBindings())
2519 {
2520 if (samplerBinding.unreferenced)
2521 continue;
2522
Corentin Wallezf0e89be2017-11-08 14:00:32 -08002523 TextureType textureType = samplerBinding.textureType;
Jamie Madill81c2e252017-09-09 23:32:46 -04002524 for (GLuint textureUnitIndex : samplerBinding.boundTextureUnits)
2525 {
2526 Texture *texture = getSamplerTexture(textureUnitIndex, textureType);
Jamie Madill06ef36b2017-09-09 23:32:46 -04002527 Sampler *sampler = getSampler(textureUnitIndex);
Jamie Madill0f80ed82017-09-19 00:24:56 -04002528 ASSERT(static_cast<size_t>(textureUnitIndex) < mCompleteTextureCache.size());
2529 ASSERT(static_cast<size_t>(textureUnitIndex) < newActiveTextures.size());
Jamie Madill81c2e252017-09-09 23:32:46 -04002530
Jamie Madill42975642017-10-12 12:31:51 -04002531 ASSERT(texture);
Jamie Madill81c2e252017-09-09 23:32:46 -04002532
Jamie Madill42975642017-10-12 12:31:51 -04002533 // Mark the texture binding bit as dirty if the texture completeness changes.
2534 // TODO(jmadill): Use specific dirty bit for completeness change.
2535 if (texture->isSamplerComplete(context, sampler) &&
2536 !mDrawFramebuffer->hasTextureAttachment(texture))
2537 {
2538 texture->syncState();
2539 mCompleteTextureCache[textureUnitIndex] = texture;
Jamie Madill81c2e252017-09-09 23:32:46 -04002540 }
Jamie Madill42975642017-10-12 12:31:51 -04002541 else
2542 {
2543 mCompleteTextureCache[textureUnitIndex] = nullptr;
2544 }
2545
2546 // Bind the texture unconditionally, to recieve completeness change notifications.
Jamie Madill888081d2018-02-27 00:24:46 -05002547 mCompleteTextureBindings[textureUnitIndex].bind(texture->getSubject());
Jamie Madilla59fc192017-11-02 12:57:58 -04002548 mActiveTexturesMask.set(textureUnitIndex);
Jamie Madill42975642017-10-12 12:31:51 -04002549 newActiveTextures.set(textureUnitIndex);
Jamie Madill81c2e252017-09-09 23:32:46 -04002550
Jamie Madill06ef36b2017-09-09 23:32:46 -04002551 if (sampler != nullptr)
2552 {
2553 sampler->syncState(context);
2554 }
Geoff Lange51ba632017-11-21 11:45:25 -05002555
2556 if (texture->initState() == InitState::MayNeedInit)
2557 {
2558 mCachedTexturesInitState = InitState::MayNeedInit;
2559 }
Jamie Madill81c2e252017-09-09 23:32:46 -04002560 }
2561 }
Jamie Madill0f80ed82017-09-19 00:24:56 -04002562
2563 // Unset now missing textures.
Jamie Madilla59fc192017-11-02 12:57:58 -04002564 ActiveTextureMask negativeMask = mActiveTexturesMask & ~newActiveTextures;
Jamie Madill0f80ed82017-09-19 00:24:56 -04002565 if (negativeMask.any())
2566 {
2567 for (auto textureIndex : negativeMask)
2568 {
2569 mCompleteTextureBindings[textureIndex].reset();
2570 mCompleteTextureCache[textureIndex] = nullptr;
Jamie Madilla59fc192017-11-02 12:57:58 -04002571 mActiveTexturesMask.reset(textureIndex);
Jamie Madill0f80ed82017-09-19 00:24:56 -04002572 }
2573 }
Jamie Madill81c2e252017-09-09 23:32:46 -04002574}
2575
Jamie Madillbc918e72018-03-08 09:47:21 -05002576Error State::syncDirtyObject(const Context *context, GLenum target)
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002577{
2578 DirtyObjects localSet;
2579
2580 switch (target)
2581 {
2582 case GL_READ_FRAMEBUFFER:
2583 localSet.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2584 break;
2585 case GL_DRAW_FRAMEBUFFER:
2586 localSet.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2587 break;
2588 case GL_FRAMEBUFFER:
2589 localSet.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2590 localSet.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2591 break;
2592 case GL_VERTEX_ARRAY:
2593 localSet.set(DIRTY_OBJECT_VERTEX_ARRAY);
2594 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002595 case GL_TEXTURE:
2596 case GL_SAMPLER:
2597 case GL_PROGRAM:
2598 localSet.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
2599 break;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002600 }
2601
Jamie Madillbc918e72018-03-08 09:47:21 -05002602 return syncDirtyObjects(context, localSet);
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002603}
2604
2605void State::setObjectDirty(GLenum target)
2606{
2607 switch (target)
2608 {
2609 case GL_READ_FRAMEBUFFER:
2610 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2611 break;
2612 case GL_DRAW_FRAMEBUFFER:
2613 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2614 break;
2615 case GL_FRAMEBUFFER:
2616 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2617 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2618 break;
2619 case GL_VERTEX_ARRAY:
2620 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
2621 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002622 case GL_TEXTURE:
2623 case GL_SAMPLER:
Jamie Madill81c2e252017-09-09 23:32:46 -04002624 case GL_PROGRAM:
2625 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
2626 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
2627 break;
Jamie Madilla779b612017-07-24 11:46:05 -04002628 }
2629}
2630
Jamie Madill888081d2018-02-27 00:24:46 -05002631void State::setFramebufferDirty(const Framebuffer *framebuffer) const
2632{
2633 if (framebuffer == mReadFramebuffer)
2634 {
2635 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2636 }
2637 if (framebuffer == mDrawFramebuffer)
2638 {
2639 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2640 }
2641}
2642
Jamie Madilla779b612017-07-24 11:46:05 -04002643void State::onProgramExecutableChange(Program *program)
2644{
2645 // OpenGL Spec:
2646 // "If LinkProgram or ProgramBinary successfully re-links a program object
2647 // that was already in use as a result of a previous call to UseProgram, then the
2648 // generated executable code will be installed as part of the current rendering state."
2649 if (program->isLinked() && mProgram == program)
2650 {
2651 mDirtyBits.set(DIRTY_BIT_PROGRAM_EXECUTABLE);
Jamie Madill81c2e252017-09-09 23:32:46 -04002652 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002653 }
Shannon Woods53a94a82014-06-24 15:20:36 -04002654}
Jamie Madillc9d442d2016-01-20 11:17:24 -05002655
Xinghua Cao65ec0b22017-03-28 16:10:52 +08002656void State::setImageUnit(const Context *context,
2657 GLuint unit,
2658 Texture *texture,
2659 GLint level,
2660 GLboolean layered,
2661 GLint layer,
2662 GLenum access,
2663 GLenum format)
2664{
2665 mImageUnits[unit].texture.set(context, texture);
2666 mImageUnits[unit].level = level;
2667 mImageUnits[unit].layered = layered;
2668 mImageUnits[unit].layer = layer;
2669 mImageUnits[unit].access = access;
2670 mImageUnits[unit].format = format;
2671}
2672
2673const ImageUnit &State::getImageUnit(GLuint unit) const
2674{
2675 return mImageUnits[unit];
2676}
2677
Jamie Madill81c2e252017-09-09 23:32:46 -04002678// Handle a dirty texture event.
Jamie Madilld4442552018-02-27 22:03:47 -05002679void State::onSubjectStateChange(const Context *context,
2680 angle::SubjectIndex index,
2681 angle::SubjectMessage message)
Jamie Madill81c2e252017-09-09 23:32:46 -04002682{
2683 // Conservatively assume all textures are dirty.
2684 // TODO(jmadill): More fine-grained update.
2685 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Geoff Lange51ba632017-11-21 11:45:25 -05002686
Jamie Madilld4442552018-02-27 22:03:47 -05002687 if (!mCompleteTextureCache[index] ||
2688 mCompleteTextureCache[index]->initState() == InitState::MayNeedInit)
Geoff Lange51ba632017-11-21 11:45:25 -05002689 {
2690 mCachedTexturesInitState = InitState::MayNeedInit;
2691 }
Jamie Madill81c2e252017-09-09 23:32:46 -04002692}
2693
Jamie Madill05b35b22017-10-03 09:01:44 -04002694Error State::clearUnclearedActiveTextures(const Context *context)
2695{
Jamie Madilla59fc192017-11-02 12:57:58 -04002696 ASSERT(mRobustResourceInit);
Jamie Madill05b35b22017-10-03 09:01:44 -04002697
Geoff Lange51ba632017-11-21 11:45:25 -05002698 if (mCachedTexturesInitState == InitState::Initialized)
2699 {
2700 return NoError();
2701 }
2702
Geoff Langd4fff502017-09-22 11:28:28 -04002703 ASSERT(!mDirtyObjects.any());
2704
Jamie Madilla59fc192017-11-02 12:57:58 -04002705 for (auto textureIndex : mActiveTexturesMask)
Jamie Madill05b35b22017-10-03 09:01:44 -04002706 {
Jamie Madilla59fc192017-11-02 12:57:58 -04002707 Texture *texture = mCompleteTextureCache[textureIndex];
Jamie Madill05b35b22017-10-03 09:01:44 -04002708 if (texture)
2709 {
2710 ANGLE_TRY(texture->ensureInitialized(context));
2711 }
2712 }
Jamie Madilla59fc192017-11-02 12:57:58 -04002713
Geoff Lange51ba632017-11-21 11:45:25 -05002714 mCachedTexturesInitState = InitState::Initialized;
2715
Jamie Madill05b35b22017-10-03 09:01:44 -04002716 return NoError();
2717}
2718
Jamie Madillc67323a2017-11-02 23:11:41 -04002719AttributesMask State::getAndResetDirtyCurrentValues() const
2720{
2721 AttributesMask retVal = mDirtyCurrentValues;
2722 mDirtyCurrentValues.reset();
2723 return retVal;
2724}
2725
James Darpiniane8a93c62018-01-04 18:02:24 -08002726bool State::isCurrentTransformFeedback(const TransformFeedback *tf) const
2727{
2728 return tf == mTransformFeedback.get();
2729}
2730bool State::isCurrentVertexArray(const VertexArray *va) const
2731{
2732 return va == mVertexArray;
2733}
2734
Jamie Madillc9d442d2016-01-20 11:17:24 -05002735} // namespace gl