blob: fd5f21966fe3920b9f39a17994460e3cfc142352 [file] [log] [blame]
Shannon Woods53a94a82014-06-24 15:20:36 -04001//
2// Copyright (c) 2014 The ANGLE Project Authors. All rights reserved.
3// Use of this source code is governed by a BSD-style license that can be
4// found in the LICENSE file.
5//
6
7// State.cpp: Implements the State class, encapsulating raw GL state.
8
Geoff Lang2b5420c2014-11-19 14:20:15 -05009#include "libANGLE/State.h"
Shannon Woods53a94a82014-06-24 15:20:36 -040010
Sami Väisänene45e53b2016-05-25 10:36:04 +030011#include <string.h>
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -070012#include <limits>
Sami Väisänene45e53b2016-05-25 10:36:04 +030013
Jamie Madill20e005b2017-04-07 14:19:22 -040014#include "common/bitset_utils.h"
Sami Väisänene45e53b2016-05-25 10:36:04 +030015#include "common/mathutil.h"
jchen10a99ed552017-09-22 08:10:32 +080016#include "common/matrix_utils.h"
Geoff Lang2b5420c2014-11-19 14:20:15 -050017#include "libANGLE/Caps.h"
jchen10a99ed552017-09-22 08:10:32 +080018#include "libANGLE/Context.h"
Geoff Lang70d0f492015-12-10 17:45:46 -050019#include "libANGLE/Debug.h"
Geoff Lang2b5420c2014-11-19 14:20:15 -050020#include "libANGLE/Framebuffer.h"
21#include "libANGLE/FramebufferAttachment.h"
22#include "libANGLE/Query.h"
23#include "libANGLE/VertexArray.h"
24#include "libANGLE/formatutils.h"
jchen10a99ed552017-09-22 08:10:32 +080025#include "libANGLE/queryconversions.h"
Lingfeng Yangabb09f12018-04-16 10:43:53 -070026#include "libANGLE/queryutils.h"
Geoff Lang4751aab2017-10-30 15:14:52 -040027#include "libANGLE/renderer/ContextImpl.h"
Shannon Woods53a94a82014-06-24 15:20:36 -040028
Olli Etuahobbf1c102016-06-28 13:31:33 +030029namespace
30{
31
32GLenum ActiveQueryType(const GLenum type)
33{
34 return (type == GL_ANY_SAMPLES_PASSED_CONSERVATIVE) ? GL_ANY_SAMPLES_PASSED : type;
35}
36
37} // anonymous namepace
38
Shannon Woods53a94a82014-06-24 15:20:36 -040039namespace gl
40{
Geoff Lang76b10c92014-09-05 16:28:14 -040041
James Darpiniane8a93c62018-01-04 18:02:24 -080042void UpdateBufferBinding(const Context *context,
43 BindingPointer<Buffer> *binding,
44 Buffer *buffer,
45 BufferBinding target)
46{
47 if (binding->get())
48 (*binding)->onBindingChanged(false, target);
49 binding->set(context, buffer);
50 if (binding->get())
51 (*binding)->onBindingChanged(true, target);
52}
53
54void UpdateBufferBinding(const Context *context,
55 OffsetBindingPointer<Buffer> *binding,
56 Buffer *buffer,
57 BufferBinding target,
58 GLintptr offset,
59 GLsizeiptr size)
60{
61 if (binding->get())
62 (*binding)->onBindingChanged(false, target);
63 binding->set(context, buffer, offset, size);
64 if (binding->get())
65 (*binding)->onBindingChanged(true, target);
66}
67
Shannon Woods53a94a82014-06-24 15:20:36 -040068State::State()
Jamie Madille79b1e12015-11-04 16:36:37 -050069 : mMaxDrawBuffers(0),
70 mMaxCombinedTextureImageUnits(0),
71 mDepthClearValue(0),
72 mStencilClearValue(0),
73 mScissorTest(false),
74 mSampleCoverage(false),
75 mSampleCoverageValue(0),
76 mSampleCoverageInvert(false),
Jiawei Shaodb342272017-09-27 10:21:45 +080077 mSampleMask(false),
78 mMaxSampleMaskWords(0),
Jamie Madille79b1e12015-11-04 16:36:37 -050079 mStencilRef(0),
80 mStencilBackRef(0),
81 mLineWidth(0),
82 mGenerateMipmapHint(GL_NONE),
83 mFragmentShaderDerivativeHint(GL_NONE),
Geoff Langf41a7152016-09-19 15:11:17 -040084 mBindGeneratesResource(true),
Geoff Langfeb8c682017-02-13 16:07:35 -050085 mClientArraysEnabled(true),
Jamie Madille79b1e12015-11-04 16:36:37 -050086 mNearZ(0),
87 mFarZ(0),
88 mReadFramebuffer(nullptr),
89 mDrawFramebuffer(nullptr),
90 mProgram(nullptr),
91 mVertexArray(nullptr),
92 mActiveSampler(0),
Sami Väisänen74c23472016-05-09 17:30:30 +030093 mPrimitiveRestart(false),
94 mMultiSampling(false),
Geoff Lang1d2c41d2016-10-19 16:14:46 -070095 mSampleAlphaToOne(false),
Jamie Madille08a1d32017-03-07 17:24:06 -050096 mFramebufferSRGB(true),
Jamie Madillc43be722017-07-13 16:22:14 -040097 mRobustResourceInit(false),
98 mProgramBinaryCacheEnabled(false)
Shannon Woods53a94a82014-06-24 15:20:36 -040099{
Geoff Lang76b10c92014-09-05 16:28:14 -0400100}
101
Lingfeng Yang13b708f2018-03-21 12:14:10 -0700102State::~State()
103{
104}
Geoff Lang76b10c92014-09-05 16:28:14 -0400105
Jamie Madill4928b7c2017-06-20 12:57:39 -0400106void State::initialize(const Context *context,
Geoff Langf41a7152016-09-19 15:11:17 -0400107 bool debug,
Geoff Langfeb8c682017-02-13 16:07:35 -0500108 bool bindGeneratesResource,
Jamie Madille08a1d32017-03-07 17:24:06 -0500109 bool clientArraysEnabled,
Jamie Madillc43be722017-07-13 16:22:14 -0400110 bool robustResourceInit,
111 bool programBinaryCacheEnabled)
Geoff Lang76b10c92014-09-05 16:28:14 -0400112{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700113 const Caps &caps = context->getCaps();
114 const Extensions &extensions = context->getExtensions();
Geoff Lang4751aab2017-10-30 15:14:52 -0400115 const Extensions &nativeExtensions = context->getImplementation()->getNativeExtensions();
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700116 const Version &clientVersion = context->getClientVersion();
Jamie Madill4928b7c2017-06-20 12:57:39 -0400117
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700118 mMaxDrawBuffers = caps.maxDrawBuffers;
Shannon Woods2df6a602014-09-26 16:12:07 -0400119 mMaxCombinedTextureImageUnits = caps.maxCombinedTextureImageUnits;
Shannon Woods53a94a82014-06-24 15:20:36 -0400120
Jamie Madillf75ab352015-03-16 10:46:52 -0400121 setColorClearValue(0.0f, 0.0f, 0.0f, 0.0f);
Shannon Woods53a94a82014-06-24 15:20:36 -0400122
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700123 mDepthClearValue = 1.0f;
Shannon Woods53a94a82014-06-24 15:20:36 -0400124 mStencilClearValue = 0;
125
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700126 mScissorTest = false;
127 mScissor.x = 0;
128 mScissor.y = 0;
129 mScissor.width = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400130 mScissor.height = 0;
131
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700132 mBlendColor.red = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400133 mBlendColor.green = 0;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700134 mBlendColor.blue = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400135 mBlendColor.alpha = 0;
136
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700137 mStencilRef = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400138 mStencilBackRef = 0;
139
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700140 mSampleCoverage = false;
141 mSampleCoverageValue = 1.0f;
Shannon Woods53a94a82014-06-24 15:20:36 -0400142 mSampleCoverageInvert = false;
Jiawei Shaodb342272017-09-27 10:21:45 +0800143
144 mMaxSampleMaskWords = caps.maxSampleMaskWords;
145 mSampleMask = false;
146 mSampleMaskValues.fill(~GLbitfield(0));
147
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700148 mGenerateMipmapHint = GL_DONT_CARE;
Shannon Woods53a94a82014-06-24 15:20:36 -0400149 mFragmentShaderDerivativeHint = GL_DONT_CARE;
150
Geoff Langf41a7152016-09-19 15:11:17 -0400151 mBindGeneratesResource = bindGeneratesResource;
Geoff Langfeb8c682017-02-13 16:07:35 -0500152 mClientArraysEnabled = clientArraysEnabled;
Geoff Langf41a7152016-09-19 15:11:17 -0400153
Shannon Woods53a94a82014-06-24 15:20:36 -0400154 mLineWidth = 1.0f;
155
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700156 mViewport.x = 0;
157 mViewport.y = 0;
158 mViewport.width = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400159 mViewport.height = 0;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700160 mNearZ = 0.0f;
161 mFarZ = 1.0f;
Shannon Woods53a94a82014-06-24 15:20:36 -0400162
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700163 mBlend.colorMaskRed = true;
Shannon Woods53a94a82014-06-24 15:20:36 -0400164 mBlend.colorMaskGreen = true;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700165 mBlend.colorMaskBlue = true;
Shannon Woods53a94a82014-06-24 15:20:36 -0400166 mBlend.colorMaskAlpha = true;
167
Geoff Lang76b10c92014-09-05 16:28:14 -0400168 mActiveSampler = 0;
169
Shannon Woods23e05002014-09-22 19:07:27 -0400170 mVertexAttribCurrentValues.resize(caps.maxVertexAttributes);
Shannon Woods53a94a82014-06-24 15:20:36 -0400171
Brandon Jonesc405ae72017-12-06 14:15:03 -0800172 // Set all indexes in state attributes type mask to float (default)
173 for (int i = 0; i < MAX_VERTEX_ATTRIBS; i++)
174 {
175 mCurrentValuesTypeMask.setIndex(GL_FLOAT, i);
176 }
177
Geoff Lang4dc3af02016-11-18 14:09:27 -0500178 mUniformBuffers.resize(caps.maxUniformBufferBindings);
Shannon Woodsf3acaf92014-09-23 18:07:11 -0400179
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800180 mSamplerTextures[TextureType::_2D].resize(caps.maxCombinedTextureImageUnits);
181 mSamplerTextures[TextureType::CubeMap].resize(caps.maxCombinedTextureImageUnits);
Geoff Langeb66a6e2016-10-31 13:06:12 -0400182 if (clientVersion >= Version(3, 0))
Shannon Woods53a94a82014-06-24 15:20:36 -0400183 {
Geoff Lang76b10c92014-09-05 16:28:14 -0400184 // TODO: These could also be enabled via extension
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800185 mSamplerTextures[TextureType::_2DArray].resize(caps.maxCombinedTextureImageUnits);
186 mSamplerTextures[TextureType::_3D].resize(caps.maxCombinedTextureImageUnits);
Shannon Woods53a94a82014-06-24 15:20:36 -0400187 }
Geoff Lang3b573612016-10-31 14:08:10 -0400188 if (clientVersion >= Version(3, 1))
189 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800190 mSamplerTextures[TextureType::_2DMultisample].resize(caps.maxCombinedTextureImageUnits);
Jiajia Qin6eafb042016-12-27 17:04:07 +0800191
192 mAtomicCounterBuffers.resize(caps.maxAtomicCounterBufferBindings);
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800193 mShaderStorageBuffers.resize(caps.maxShaderStorageBufferBindings);
Xinghua Cao65ec0b22017-03-28 16:10:52 +0800194 mImageUnits.resize(caps.maxImageUnits);
Geoff Lang3b573612016-10-31 14:08:10 -0400195 }
Geoff Lang4751aab2017-10-30 15:14:52 -0400196 if (nativeExtensions.textureRectangle)
Corentin Wallez13c0dd42017-07-04 18:27:01 -0400197 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800198 mSamplerTextures[TextureType::Rectangle].resize(caps.maxCombinedTextureImageUnits);
Corentin Wallez13c0dd42017-07-04 18:27:01 -0400199 }
Geoff Lang4751aab2017-10-30 15:14:52 -0400200 if (nativeExtensions.eglImageExternal || nativeExtensions.eglStreamConsumerExternal)
Ian Ewellbda75592016-04-18 17:25:54 -0400201 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800202 mSamplerTextures[TextureType::External].resize(caps.maxCombinedTextureImageUnits);
Ian Ewellbda75592016-04-18 17:25:54 -0400203 }
Jamie Madill81c2e252017-09-09 23:32:46 -0400204 mCompleteTextureCache.resize(caps.maxCombinedTextureImageUnits, nullptr);
205 mCompleteTextureBindings.reserve(caps.maxCombinedTextureImageUnits);
Geoff Lange51ba632017-11-21 11:45:25 -0500206 mCachedTexturesInitState = InitState::MayNeedInit;
Jamie Madill81c2e252017-09-09 23:32:46 -0400207 for (uint32_t textureIndex = 0; textureIndex < caps.maxCombinedTextureImageUnits;
208 ++textureIndex)
209 {
Jamie Madilld4442552018-02-27 22:03:47 -0500210 mCompleteTextureBindings.emplace_back(this, textureIndex);
Jamie Madill81c2e252017-09-09 23:32:46 -0400211 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400212
Geoff Lang76b10c92014-09-05 16:28:14 -0400213 mSamplers.resize(caps.maxCombinedTextureImageUnits);
Shannon Woods53a94a82014-06-24 15:20:36 -0400214
Jamie Madill4928b7c2017-06-20 12:57:39 -0400215 mActiveQueries[GL_ANY_SAMPLES_PASSED].set(context, nullptr);
216 mActiveQueries[GL_ANY_SAMPLES_PASSED_CONSERVATIVE].set(context, nullptr);
217 mActiveQueries[GL_TRANSFORM_FEEDBACK_PRIMITIVES_WRITTEN].set(context, nullptr);
218 mActiveQueries[GL_TIME_ELAPSED_EXT].set(context, nullptr);
219 mActiveQueries[GL_COMMANDS_COMPLETED_CHROMIUM].set(context, nullptr);
Jiawei Shaod2fa07e2018-03-15 09:20:25 +0800220 mActiveQueries[GL_PRIMITIVES_GENERATED_EXT].set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400221
Ian Ewell3ffd78b2016-01-22 16:09:42 -0500222 mProgram = nullptr;
Shannon Woods53a94a82014-06-24 15:20:36 -0400223
Ian Ewell3ffd78b2016-01-22 16:09:42 -0500224 mReadFramebuffer = nullptr;
225 mDrawFramebuffer = nullptr;
Jamie Madillb4b53c52015-02-03 15:22:48 -0500226
227 mPrimitiveRestart = false;
Geoff Lang70d0f492015-12-10 17:45:46 -0500228
229 mDebug.setOutputEnabled(debug);
230 mDebug.setMaxLoggedMessages(extensions.maxDebugLoggedMessages);
Sami Väisänen74c23472016-05-09 17:30:30 +0300231
Geoff Lang488130e2017-09-27 13:53:11 -0400232 mMultiSampling = true;
233 mSampleAlphaToOne = false;
Sami Väisänena797e062016-05-12 15:23:40 +0300234
235 mCoverageModulation = GL_NONE;
Sami Väisänene45e53b2016-05-25 10:36:04 +0300236
237 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixProj);
238 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixMV);
239 mPathStencilFunc = GL_ALWAYS;
240 mPathStencilRef = 0;
241 mPathStencilMask = std::numeric_limits<GLuint>::max();
Jamie Madille08a1d32017-03-07 17:24:06 -0500242
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700243 mRobustResourceInit = robustResourceInit;
Jamie Madillc43be722017-07-13 16:22:14 -0400244 mProgramBinaryCacheEnabled = programBinaryCacheEnabled;
Lingfeng Yangdbb9c532018-02-25 19:58:24 -0800245
246 // GLES1 emulation: Initialize state for GLES1 if version
247 // applies
248 if (clientVersion < Version(2, 0))
249 {
Lingfeng Yange547aac2018-04-05 09:39:20 -0700250 mGLES1State.initialize(context, this);
Lingfeng Yangdbb9c532018-02-25 19:58:24 -0800251 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400252}
253
Jamie Madill6c1f6712017-02-14 19:08:04 -0500254void State::reset(const Context *context)
Shannon Woods53a94a82014-06-24 15:20:36 -0400255{
Jamie Madill8693bdb2017-09-02 15:32:14 -0400256 for (auto &bindingVec : mSamplerTextures)
Shannon Woods53a94a82014-06-24 15:20:36 -0400257 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800258 for (size_t textureIdx = 0; textureIdx < bindingVec.size(); textureIdx++)
Shannon Woods53a94a82014-06-24 15:20:36 -0400259 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800260 bindingVec[textureIdx].set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400261 }
262 }
Geoff Lang76b10c92014-09-05 16:28:14 -0400263 for (size_t samplerIdx = 0; samplerIdx < mSamplers.size(); samplerIdx++)
264 {
Jamie Madill4928b7c2017-06-20 12:57:39 -0400265 mSamplers[samplerIdx].set(context, nullptr);
Geoff Lang76b10c92014-09-05 16:28:14 -0400266 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400267
Xinghua Cao65ec0b22017-03-28 16:10:52 +0800268 for (auto &imageUnit : mImageUnits)
269 {
270 imageUnit.texture.set(context, nullptr);
271 imageUnit.level = 0;
272 imageUnit.layered = false;
273 imageUnit.layer = 0;
274 imageUnit.access = GL_READ_ONLY;
275 imageUnit.format = GL_R32UI;
276 }
277
Jamie Madill4928b7c2017-06-20 12:57:39 -0400278 mRenderbuffer.set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400279
Corentin Wallez336129f2017-10-17 15:55:40 -0400280 for (auto type : angle::AllEnums<BufferBinding>())
281 {
James Darpiniane8a93c62018-01-04 18:02:24 -0800282 UpdateBufferBinding(context, &mBoundBuffers[type], nullptr, type);
Corentin Wallez336129f2017-10-17 15:55:40 -0400283 }
284
Geoff Lang7dd2e102014-11-10 15:19:26 -0500285 if (mProgram)
286 {
Jamie Madill6c1f6712017-02-14 19:08:04 -0500287 mProgram->release(context);
Geoff Lang7dd2e102014-11-10 15:19:26 -0500288 }
Yunchao Hed7297bf2017-04-19 15:27:10 +0800289 mProgram = nullptr;
Geoff Lang7dd2e102014-11-10 15:19:26 -0500290
Yunchao Hea336b902017-08-02 16:05:21 +0800291 mProgramPipeline.set(context, nullptr);
292
James Darpiniane8a93c62018-01-04 18:02:24 -0800293 if (mTransformFeedback.get())
294 mTransformFeedback->onBindingChanged(false);
Jamie Madill4928b7c2017-06-20 12:57:39 -0400295 mTransformFeedback.set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400296
297 for (State::ActiveQueryMap::iterator i = mActiveQueries.begin(); i != mActiveQueries.end(); i++)
298 {
Jamie Madill4928b7c2017-06-20 12:57:39 -0400299 i->second.set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400300 }
301
Corentin Wallez336129f2017-10-17 15:55:40 -0400302 for (auto &buf : mUniformBuffers)
Shannon Woods53a94a82014-06-24 15:20:36 -0400303 {
James Darpiniane8a93c62018-01-04 18:02:24 -0800304 UpdateBufferBinding(context, &buf, nullptr, BufferBinding::Uniform);
Shannon Woods53a94a82014-06-24 15:20:36 -0400305 }
306
Jiajia Qin6eafb042016-12-27 17:04:07 +0800307 for (auto &buf : mAtomicCounterBuffers)
308 {
James Darpiniane8a93c62018-01-04 18:02:24 -0800309 UpdateBufferBinding(context, &buf, nullptr, BufferBinding::AtomicCounter);
Jiajia Qin6eafb042016-12-27 17:04:07 +0800310 }
311
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800312 for (auto &buf : mShaderStorageBuffers)
313 {
James Darpiniane8a93c62018-01-04 18:02:24 -0800314 UpdateBufferBinding(context, &buf, nullptr, BufferBinding::ShaderStorage);
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800315 }
316
Sami Väisänene45e53b2016-05-25 10:36:04 +0300317 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixProj);
318 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixMV);
319 mPathStencilFunc = GL_ALWAYS;
320 mPathStencilRef = 0;
321 mPathStencilMask = std::numeric_limits<GLuint>::max();
322
Jamie Madill1b94d432015-08-07 13:23:23 -0400323 // TODO(jmadill): Is this necessary?
324 setAllDirtyBits();
Shannon Woods53a94a82014-06-24 15:20:36 -0400325}
326
327const RasterizerState &State::getRasterizerState() const
328{
329 return mRasterizer;
330}
331
332const BlendState &State::getBlendState() const
333{
334 return mBlend;
335}
336
337const DepthStencilState &State::getDepthStencilState() const
338{
339 return mDepthStencil;
340}
341
Jamie Madillf75ab352015-03-16 10:46:52 -0400342void State::setColorClearValue(float red, float green, float blue, float alpha)
Shannon Woods53a94a82014-06-24 15:20:36 -0400343{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700344 mColorClearValue.red = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400345 mColorClearValue.green = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700346 mColorClearValue.blue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400347 mColorClearValue.alpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400348 mDirtyBits.set(DIRTY_BIT_CLEAR_COLOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400349}
350
Jamie Madillf75ab352015-03-16 10:46:52 -0400351void State::setDepthClearValue(float depth)
Shannon Woods53a94a82014-06-24 15:20:36 -0400352{
353 mDepthClearValue = depth;
Jamie Madill1b94d432015-08-07 13:23:23 -0400354 mDirtyBits.set(DIRTY_BIT_CLEAR_DEPTH);
Shannon Woods53a94a82014-06-24 15:20:36 -0400355}
356
Jamie Madillf75ab352015-03-16 10:46:52 -0400357void State::setStencilClearValue(int stencil)
Shannon Woods53a94a82014-06-24 15:20:36 -0400358{
359 mStencilClearValue = stencil;
Jamie Madill1b94d432015-08-07 13:23:23 -0400360 mDirtyBits.set(DIRTY_BIT_CLEAR_STENCIL);
Shannon Woods53a94a82014-06-24 15:20:36 -0400361}
362
Shannon Woods53a94a82014-06-24 15:20:36 -0400363void State::setColorMask(bool red, bool green, bool blue, bool alpha)
364{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700365 mBlend.colorMaskRed = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400366 mBlend.colorMaskGreen = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700367 mBlend.colorMaskBlue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400368 mBlend.colorMaskAlpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400369 mDirtyBits.set(DIRTY_BIT_COLOR_MASK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400370}
371
372void State::setDepthMask(bool mask)
373{
374 mDepthStencil.depthMask = mask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400375 mDirtyBits.set(DIRTY_BIT_DEPTH_MASK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400376}
377
378bool State::isRasterizerDiscardEnabled() const
379{
380 return mRasterizer.rasterizerDiscard;
381}
382
383void State::setRasterizerDiscard(bool enabled)
384{
385 mRasterizer.rasterizerDiscard = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400386 mDirtyBits.set(DIRTY_BIT_RASTERIZER_DISCARD_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400387}
388
389bool State::isCullFaceEnabled() const
390{
391 return mRasterizer.cullFace;
392}
393
394void State::setCullFace(bool enabled)
395{
396 mRasterizer.cullFace = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400397 mDirtyBits.set(DIRTY_BIT_CULL_FACE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400398}
399
Corentin Wallez2e568cf2017-09-18 17:05:22 -0400400void State::setCullMode(CullFaceMode mode)
Shannon Woods53a94a82014-06-24 15:20:36 -0400401{
402 mRasterizer.cullMode = mode;
Jamie Madill1b94d432015-08-07 13:23:23 -0400403 mDirtyBits.set(DIRTY_BIT_CULL_FACE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400404}
405
406void State::setFrontFace(GLenum front)
407{
408 mRasterizer.frontFace = front;
Jamie Madill1b94d432015-08-07 13:23:23 -0400409 mDirtyBits.set(DIRTY_BIT_FRONT_FACE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400410}
411
412bool State::isDepthTestEnabled() const
413{
414 return mDepthStencil.depthTest;
415}
416
417void State::setDepthTest(bool enabled)
418{
419 mDepthStencil.depthTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400420 mDirtyBits.set(DIRTY_BIT_DEPTH_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400421}
422
423void State::setDepthFunc(GLenum depthFunc)
424{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700425 mDepthStencil.depthFunc = depthFunc;
426 mDirtyBits.set(DIRTY_BIT_DEPTH_FUNC);
Shannon Woods53a94a82014-06-24 15:20:36 -0400427}
428
429void State::setDepthRange(float zNear, float zFar)
430{
431 mNearZ = zNear;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700432 mFarZ = zFar;
Jamie Madill1b94d432015-08-07 13:23:23 -0400433 mDirtyBits.set(DIRTY_BIT_DEPTH_RANGE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400434}
435
Geoff Langd42f5b82015-04-16 14:03:29 -0400436float State::getNearPlane() const
Shannon Woods53a94a82014-06-24 15:20:36 -0400437{
Geoff Langd42f5b82015-04-16 14:03:29 -0400438 return mNearZ;
439}
440
441float State::getFarPlane() const
442{
443 return mFarZ;
Shannon Woods53a94a82014-06-24 15:20:36 -0400444}
445
446bool State::isBlendEnabled() const
447{
448 return mBlend.blend;
449}
450
451void State::setBlend(bool enabled)
452{
453 mBlend.blend = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400454 mDirtyBits.set(DIRTY_BIT_BLEND_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400455}
456
457void State::setBlendFactors(GLenum sourceRGB, GLenum destRGB, GLenum sourceAlpha, GLenum destAlpha)
458{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700459 mBlend.sourceBlendRGB = sourceRGB;
460 mBlend.destBlendRGB = destRGB;
Shannon Woods53a94a82014-06-24 15:20:36 -0400461 mBlend.sourceBlendAlpha = sourceAlpha;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700462 mBlend.destBlendAlpha = destAlpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400463 mDirtyBits.set(DIRTY_BIT_BLEND_FUNCS);
Shannon Woods53a94a82014-06-24 15:20:36 -0400464}
465
466void State::setBlendColor(float red, float green, float blue, float alpha)
467{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700468 mBlendColor.red = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400469 mBlendColor.green = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700470 mBlendColor.blue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400471 mBlendColor.alpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400472 mDirtyBits.set(DIRTY_BIT_BLEND_COLOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400473}
474
475void State::setBlendEquation(GLenum rgbEquation, GLenum alphaEquation)
476{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700477 mBlend.blendEquationRGB = rgbEquation;
Shannon Woods53a94a82014-06-24 15:20:36 -0400478 mBlend.blendEquationAlpha = alphaEquation;
Jamie Madill1b94d432015-08-07 13:23:23 -0400479 mDirtyBits.set(DIRTY_BIT_BLEND_EQUATIONS);
Shannon Woods53a94a82014-06-24 15:20:36 -0400480}
481
482const ColorF &State::getBlendColor() const
483{
484 return mBlendColor;
485}
486
487bool State::isStencilTestEnabled() const
488{
489 return mDepthStencil.stencilTest;
490}
491
492void State::setStencilTest(bool enabled)
493{
494 mDepthStencil.stencilTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400495 mDirtyBits.set(DIRTY_BIT_STENCIL_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400496}
497
498void State::setStencilParams(GLenum stencilFunc, GLint stencilRef, GLuint stencilMask)
499{
500 mDepthStencil.stencilFunc = stencilFunc;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700501 mStencilRef = (stencilRef > 0) ? stencilRef : 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400502 mDepthStencil.stencilMask = stencilMask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400503 mDirtyBits.set(DIRTY_BIT_STENCIL_FUNCS_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400504}
505
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700506void State::setStencilBackParams(GLenum stencilBackFunc,
507 GLint stencilBackRef,
508 GLuint stencilBackMask)
Shannon Woods53a94a82014-06-24 15:20:36 -0400509{
510 mDepthStencil.stencilBackFunc = stencilBackFunc;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700511 mStencilBackRef = (stencilBackRef > 0) ? stencilBackRef : 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400512 mDepthStencil.stencilBackMask = stencilBackMask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400513 mDirtyBits.set(DIRTY_BIT_STENCIL_FUNCS_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400514}
515
516void State::setStencilWritemask(GLuint stencilWritemask)
517{
518 mDepthStencil.stencilWritemask = stencilWritemask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400519 mDirtyBits.set(DIRTY_BIT_STENCIL_WRITEMASK_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400520}
521
522void State::setStencilBackWritemask(GLuint stencilBackWritemask)
523{
524 mDepthStencil.stencilBackWritemask = stencilBackWritemask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400525 mDirtyBits.set(DIRTY_BIT_STENCIL_WRITEMASK_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400526}
527
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700528void State::setStencilOperations(GLenum stencilFail,
529 GLenum stencilPassDepthFail,
530 GLenum stencilPassDepthPass)
Shannon Woods53a94a82014-06-24 15:20:36 -0400531{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700532 mDepthStencil.stencilFail = stencilFail;
Shannon Woods53a94a82014-06-24 15:20:36 -0400533 mDepthStencil.stencilPassDepthFail = stencilPassDepthFail;
534 mDepthStencil.stencilPassDepthPass = stencilPassDepthPass;
Jamie Madill1b94d432015-08-07 13:23:23 -0400535 mDirtyBits.set(DIRTY_BIT_STENCIL_OPS_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400536}
537
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700538void State::setStencilBackOperations(GLenum stencilBackFail,
539 GLenum stencilBackPassDepthFail,
540 GLenum stencilBackPassDepthPass)
Shannon Woods53a94a82014-06-24 15:20:36 -0400541{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700542 mDepthStencil.stencilBackFail = stencilBackFail;
Shannon Woods53a94a82014-06-24 15:20:36 -0400543 mDepthStencil.stencilBackPassDepthFail = stencilBackPassDepthFail;
544 mDepthStencil.stencilBackPassDepthPass = stencilBackPassDepthPass;
Jamie Madill1b94d432015-08-07 13:23:23 -0400545 mDirtyBits.set(DIRTY_BIT_STENCIL_OPS_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400546}
547
548GLint State::getStencilRef() const
549{
550 return mStencilRef;
551}
552
553GLint State::getStencilBackRef() const
554{
555 return mStencilBackRef;
556}
557
558bool State::isPolygonOffsetFillEnabled() const
559{
560 return mRasterizer.polygonOffsetFill;
561}
562
563void State::setPolygonOffsetFill(bool enabled)
564{
Jamie Madill1b94d432015-08-07 13:23:23 -0400565 mRasterizer.polygonOffsetFill = enabled;
566 mDirtyBits.set(DIRTY_BIT_POLYGON_OFFSET_FILL_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400567}
568
569void State::setPolygonOffsetParams(GLfloat factor, GLfloat units)
570{
571 // An application can pass NaN values here, so handle this gracefully
572 mRasterizer.polygonOffsetFactor = factor != factor ? 0.0f : factor;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700573 mRasterizer.polygonOffsetUnits = units != units ? 0.0f : units;
Jamie Madill1b94d432015-08-07 13:23:23 -0400574 mDirtyBits.set(DIRTY_BIT_POLYGON_OFFSET);
Shannon Woods53a94a82014-06-24 15:20:36 -0400575}
576
577bool State::isSampleAlphaToCoverageEnabled() const
578{
579 return mBlend.sampleAlphaToCoverage;
580}
581
582void State::setSampleAlphaToCoverage(bool enabled)
583{
584 mBlend.sampleAlphaToCoverage = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400585 mDirtyBits.set(DIRTY_BIT_SAMPLE_ALPHA_TO_COVERAGE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400586}
587
588bool State::isSampleCoverageEnabled() const
589{
590 return mSampleCoverage;
591}
592
593void State::setSampleCoverage(bool enabled)
594{
595 mSampleCoverage = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400596 mDirtyBits.set(DIRTY_BIT_SAMPLE_COVERAGE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400597}
598
599void State::setSampleCoverageParams(GLclampf value, bool invert)
600{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700601 mSampleCoverageValue = value;
Shannon Woods53a94a82014-06-24 15:20:36 -0400602 mSampleCoverageInvert = invert;
Jamie Madill1b94d432015-08-07 13:23:23 -0400603 mDirtyBits.set(DIRTY_BIT_SAMPLE_COVERAGE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400604}
605
Geoff Lang0fbb6002015-04-16 11:11:53 -0400606GLclampf State::getSampleCoverageValue() const
Shannon Woods53a94a82014-06-24 15:20:36 -0400607{
Geoff Lang0fbb6002015-04-16 11:11:53 -0400608 return mSampleCoverageValue;
609}
Shannon Woods53a94a82014-06-24 15:20:36 -0400610
Geoff Lang0fbb6002015-04-16 11:11:53 -0400611bool State::getSampleCoverageInvert() const
612{
613 return mSampleCoverageInvert;
Shannon Woods53a94a82014-06-24 15:20:36 -0400614}
615
Jiawei Shaodb342272017-09-27 10:21:45 +0800616bool State::isSampleMaskEnabled() const
617{
618 return mSampleMask;
619}
620
621void State::setSampleMaskEnabled(bool enabled)
622{
623 mSampleMask = enabled;
624 mDirtyBits.set(DIRTY_BIT_SAMPLE_MASK_ENABLED);
625}
626
627void State::setSampleMaskParams(GLuint maskNumber, GLbitfield mask)
628{
629 ASSERT(maskNumber < mMaxSampleMaskWords);
630 mSampleMaskValues[maskNumber] = mask;
Jamie Madillc67323a2017-11-02 23:11:41 -0400631 // TODO(jmadill): Use a child dirty bit if we ever use more than two words.
632 mDirtyBits.set(DIRTY_BIT_SAMPLE_MASK);
Jiawei Shaodb342272017-09-27 10:21:45 +0800633}
634
635GLbitfield State::getSampleMaskWord(GLuint maskNumber) const
636{
637 ASSERT(maskNumber < mMaxSampleMaskWords);
638 return mSampleMaskValues[maskNumber];
639}
640
641GLuint State::getMaxSampleMaskWords() const
642{
643 return mMaxSampleMaskWords;
644}
645
Sami Väisänen74c23472016-05-09 17:30:30 +0300646void State::setSampleAlphaToOne(bool enabled)
647{
648 mSampleAlphaToOne = enabled;
649 mDirtyBits.set(DIRTY_BIT_SAMPLE_ALPHA_TO_ONE);
650}
651
652bool State::isSampleAlphaToOneEnabled() const
653{
654 return mSampleAlphaToOne;
655}
656
657void State::setMultisampling(bool enabled)
658{
659 mMultiSampling = enabled;
660 mDirtyBits.set(DIRTY_BIT_MULTISAMPLING);
661}
662
663bool State::isMultisamplingEnabled() const
664{
665 return mMultiSampling;
666}
667
Shannon Woods53a94a82014-06-24 15:20:36 -0400668bool State::isScissorTestEnabled() const
669{
670 return mScissorTest;
671}
672
673void State::setScissorTest(bool enabled)
674{
675 mScissorTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400676 mDirtyBits.set(DIRTY_BIT_SCISSOR_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400677}
678
679void State::setScissorParams(GLint x, GLint y, GLsizei width, GLsizei height)
680{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700681 mScissor.x = x;
682 mScissor.y = y;
683 mScissor.width = width;
Shannon Woods53a94a82014-06-24 15:20:36 -0400684 mScissor.height = height;
Jamie Madill1b94d432015-08-07 13:23:23 -0400685 mDirtyBits.set(DIRTY_BIT_SCISSOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400686}
687
688const Rectangle &State::getScissor() const
689{
690 return mScissor;
691}
692
693bool State::isDitherEnabled() const
694{
695 return mBlend.dither;
696}
697
698void State::setDither(bool enabled)
699{
700 mBlend.dither = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400701 mDirtyBits.set(DIRTY_BIT_DITHER_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400702}
703
Jamie Madillb4b53c52015-02-03 15:22:48 -0500704bool State::isPrimitiveRestartEnabled() const
705{
706 return mPrimitiveRestart;
707}
708
709void State::setPrimitiveRestart(bool enabled)
710{
711 mPrimitiveRestart = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400712 mDirtyBits.set(DIRTY_BIT_PRIMITIVE_RESTART_ENABLED);
Jamie Madillb4b53c52015-02-03 15:22:48 -0500713}
714
Shannon Woods53a94a82014-06-24 15:20:36 -0400715void State::setEnableFeature(GLenum feature, bool enabled)
716{
717 switch (feature)
718 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700719 case GL_MULTISAMPLE_EXT:
720 setMultisampling(enabled);
721 break;
722 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
723 setSampleAlphaToOne(enabled);
724 break;
725 case GL_CULL_FACE:
726 setCullFace(enabled);
727 break;
728 case GL_POLYGON_OFFSET_FILL:
729 setPolygonOffsetFill(enabled);
730 break;
731 case GL_SAMPLE_ALPHA_TO_COVERAGE:
732 setSampleAlphaToCoverage(enabled);
733 break;
734 case GL_SAMPLE_COVERAGE:
735 setSampleCoverage(enabled);
736 break;
737 case GL_SCISSOR_TEST:
738 setScissorTest(enabled);
739 break;
740 case GL_STENCIL_TEST:
741 setStencilTest(enabled);
742 break;
743 case GL_DEPTH_TEST:
744 setDepthTest(enabled);
745 break;
746 case GL_BLEND:
747 setBlend(enabled);
748 break;
749 case GL_DITHER:
750 setDither(enabled);
751 break;
752 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
753 setPrimitiveRestart(enabled);
754 break;
755 case GL_RASTERIZER_DISCARD:
756 setRasterizerDiscard(enabled);
757 break;
758 case GL_SAMPLE_MASK:
759 setSampleMaskEnabled(enabled);
760 break;
761 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
762 mDebug.setOutputSynchronous(enabled);
763 break;
764 case GL_DEBUG_OUTPUT:
765 mDebug.setOutputEnabled(enabled);
766 break;
767 case GL_FRAMEBUFFER_SRGB_EXT:
768 setFramebufferSRGB(enabled);
769 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -0700770
771 // GLES1 emulation
772 case GL_ALPHA_TEST:
773 mGLES1State.mAlphaTestEnabled = enabled;
774 break;
775
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700776 default:
777 UNREACHABLE();
Shannon Woods53a94a82014-06-24 15:20:36 -0400778 }
779}
780
Jamie Madilldfde6ab2016-06-09 07:07:18 -0700781bool State::getEnableFeature(GLenum feature) const
Shannon Woods53a94a82014-06-24 15:20:36 -0400782{
783 switch (feature)
784 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700785 case GL_MULTISAMPLE_EXT:
786 return isMultisamplingEnabled();
787 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
788 return isSampleAlphaToOneEnabled();
789 case GL_CULL_FACE:
790 return isCullFaceEnabled();
791 case GL_POLYGON_OFFSET_FILL:
792 return isPolygonOffsetFillEnabled();
793 case GL_SAMPLE_ALPHA_TO_COVERAGE:
794 return isSampleAlphaToCoverageEnabled();
795 case GL_SAMPLE_COVERAGE:
796 return isSampleCoverageEnabled();
797 case GL_SCISSOR_TEST:
798 return isScissorTestEnabled();
799 case GL_STENCIL_TEST:
800 return isStencilTestEnabled();
801 case GL_DEPTH_TEST:
802 return isDepthTestEnabled();
803 case GL_BLEND:
804 return isBlendEnabled();
805 case GL_DITHER:
806 return isDitherEnabled();
807 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
808 return isPrimitiveRestartEnabled();
809 case GL_RASTERIZER_DISCARD:
810 return isRasterizerDiscardEnabled();
811 case GL_SAMPLE_MASK:
812 return isSampleMaskEnabled();
813 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
814 return mDebug.isOutputSynchronous();
815 case GL_DEBUG_OUTPUT:
816 return mDebug.isOutputEnabled();
817 case GL_BIND_GENERATES_RESOURCE_CHROMIUM:
818 return isBindGeneratesResourceEnabled();
819 case GL_CLIENT_ARRAYS_ANGLE:
820 return areClientArraysEnabled();
821 case GL_FRAMEBUFFER_SRGB_EXT:
822 return getFramebufferSRGB();
823 case GL_ROBUST_RESOURCE_INITIALIZATION_ANGLE:
824 return mRobustResourceInit;
825 case GL_PROGRAM_CACHE_ENABLED_ANGLE:
826 return mProgramBinaryCacheEnabled;
Jamie Madillc43be722017-07-13 16:22:14 -0400827
Lingfeng Yang13b708f2018-03-21 12:14:10 -0700828 // GLES1 emulation
829 case GL_ALPHA_TEST:
830 return mGLES1State.mAlphaTestEnabled;
Lingfeng Yang01074432018-04-16 10:19:51 -0700831 case GL_VERTEX_ARRAY:
832 return mGLES1State.mVertexArrayEnabled;
833 case GL_NORMAL_ARRAY:
834 return mGLES1State.mNormalArrayEnabled;
835 case GL_COLOR_ARRAY:
836 return mGLES1State.mColorArrayEnabled;
837 case GL_POINT_SIZE_ARRAY_OES:
838 return mGLES1State.mPointSizeArrayEnabled;
839 case GL_TEXTURE_COORD_ARRAY:
840 return mGLES1State.mTexCoordArrayEnabled[mGLES1State.mClientActiveTexture];
Lingfeng Yang13b708f2018-03-21 12:14:10 -0700841
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700842 default:
843 UNREACHABLE();
844 return false;
Shannon Woods53a94a82014-06-24 15:20:36 -0400845 }
846}
847
848void State::setLineWidth(GLfloat width)
849{
850 mLineWidth = width;
Jamie Madill1b94d432015-08-07 13:23:23 -0400851 mDirtyBits.set(DIRTY_BIT_LINE_WIDTH);
Shannon Woods53a94a82014-06-24 15:20:36 -0400852}
853
Geoff Lang4b3f4162015-04-16 13:22:05 -0400854float State::getLineWidth() const
855{
856 return mLineWidth;
857}
858
Shannon Woods53a94a82014-06-24 15:20:36 -0400859void State::setGenerateMipmapHint(GLenum hint)
860{
861 mGenerateMipmapHint = hint;
Jamie Madill1b94d432015-08-07 13:23:23 -0400862 mDirtyBits.set(DIRTY_BIT_GENERATE_MIPMAP_HINT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400863}
864
865void State::setFragmentShaderDerivativeHint(GLenum hint)
866{
867 mFragmentShaderDerivativeHint = hint;
Jamie Madill1b94d432015-08-07 13:23:23 -0400868 mDirtyBits.set(DIRTY_BIT_SHADER_DERIVATIVE_HINT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400869 // TODO: Propagate the hint to shader translator so we can write
870 // ddx, ddx_coarse, or ddx_fine depending on the hint.
871 // Ignore for now. It is valid for implementations to ignore hint.
872}
873
Geoff Langf41a7152016-09-19 15:11:17 -0400874bool State::isBindGeneratesResourceEnabled() const
875{
876 return mBindGeneratesResource;
877}
878
Geoff Langfeb8c682017-02-13 16:07:35 -0500879bool State::areClientArraysEnabled() const
880{
881 return mClientArraysEnabled;
882}
883
Shannon Woods53a94a82014-06-24 15:20:36 -0400884void State::setViewportParams(GLint x, GLint y, GLsizei width, GLsizei height)
885{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700886 mViewport.x = x;
887 mViewport.y = y;
888 mViewport.width = width;
Shannon Woods53a94a82014-06-24 15:20:36 -0400889 mViewport.height = height;
Jamie Madill1b94d432015-08-07 13:23:23 -0400890 mDirtyBits.set(DIRTY_BIT_VIEWPORT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400891}
892
893const Rectangle &State::getViewport() const
894{
895 return mViewport;
896}
897
898void State::setActiveSampler(unsigned int active)
899{
900 mActiveSampler = active;
901}
902
903unsigned int State::getActiveSampler() const
904{
Cooper Partin4d61f7e2015-08-12 10:56:50 -0700905 return static_cast<unsigned int>(mActiveSampler);
Shannon Woods53a94a82014-06-24 15:20:36 -0400906}
907
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800908void State::setSamplerTexture(const Context *context, TextureType type, Texture *texture)
Shannon Woods53a94a82014-06-24 15:20:36 -0400909{
Jamie Madill4928b7c2017-06-20 12:57:39 -0400910 mSamplerTextures[type][mActiveSampler].set(context, texture);
Jamie Madill81c2e252017-09-09 23:32:46 -0400911 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
912 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Shannon Woods53a94a82014-06-24 15:20:36 -0400913}
914
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800915Texture *State::getTargetTexture(TextureType type) const
Jamie Madillc29968b2016-01-20 11:17:23 -0500916{
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800917 return getSamplerTexture(static_cast<unsigned int>(mActiveSampler), type);
Jamie Madillc29968b2016-01-20 11:17:23 -0500918}
919
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800920Texture *State::getSamplerTexture(unsigned int sampler, TextureType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -0400921{
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800922 ASSERT(sampler < mSamplerTextures[type].size());
923 return mSamplerTextures[type][sampler].get();
Shannon Woods53a94a82014-06-24 15:20:36 -0400924}
925
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800926GLuint State::getSamplerTextureId(unsigned int sampler, TextureType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -0400927{
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800928 ASSERT(sampler < mSamplerTextures[type].size());
929 return mSamplerTextures[type][sampler].id();
Shannon Woods53a94a82014-06-24 15:20:36 -0400930}
931
Jamie Madilla02315b2017-02-23 14:14:47 -0500932void State::detachTexture(const Context *context, const TextureMap &zeroTextures, GLuint texture)
Shannon Woods53a94a82014-06-24 15:20:36 -0400933{
934 // Textures have a detach method on State rather than a simple
935 // removeBinding, because the zero/null texture objects are managed
936 // separately, and don't have to go through the Context's maps or
937 // the ResourceManager.
938
939 // [OpenGL ES 2.0.24] section 3.8 page 84:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700940 // If a texture object is deleted, it is as if all texture units which are bound to that texture
941 // object are rebound to texture object zero
Shannon Woods53a94a82014-06-24 15:20:36 -0400942
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800943 for (TextureType type : angle::AllEnums<TextureType>())
Shannon Woods53a94a82014-06-24 15:20:36 -0400944 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800945 TextureBindingVector &textureVector = mSamplerTextures[type];
Jamie Madill81c2e252017-09-09 23:32:46 -0400946 for (BindingPointer<Texture> &binding : textureVector)
Shannon Woods53a94a82014-06-24 15:20:36 -0400947 {
Geoff Lang76b10c92014-09-05 16:28:14 -0400948 if (binding.id() == texture)
Shannon Woods53a94a82014-06-24 15:20:36 -0400949 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800950 Texture *zeroTexture = zeroTextures[type].get();
951 ASSERT(zeroTexture != nullptr);
Jamie Madille6382c32014-11-07 15:05:26 -0500952 // Zero textures are the "default" textures instead of NULL
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800953 binding.set(context, zeroTexture);
Jamie Madill81c2e252017-09-09 23:32:46 -0400954 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
Shannon Woods53a94a82014-06-24 15:20:36 -0400955 }
956 }
957 }
958
Xinghua Cao65ec0b22017-03-28 16:10:52 +0800959 for (auto &bindingImageUnit : mImageUnits)
960 {
961 if (bindingImageUnit.texture.id() == texture)
962 {
963 bindingImageUnit.texture.set(context, nullptr);
964 bindingImageUnit.level = 0;
965 bindingImageUnit.layered = false;
966 bindingImageUnit.layer = 0;
967 bindingImageUnit.access = GL_READ_ONLY;
968 bindingImageUnit.format = GL_R32UI;
969 break;
970 }
971 }
972
Shannon Woods53a94a82014-06-24 15:20:36 -0400973 // [OpenGL ES 2.0.24] section 4.4 page 112:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700974 // If a texture object is deleted while its image is attached to the currently bound
975 // framebuffer, then it is as if Texture2DAttachment had been called, with a texture of 0, for
976 // each attachment point to which this image was attached in the currently bound framebuffer.
Shannon Woods53a94a82014-06-24 15:20:36 -0400977
Jamie Madill8693bdb2017-09-02 15:32:14 -0400978 if (mReadFramebuffer && mReadFramebuffer->detachTexture(context, texture))
Shannon Woods53a94a82014-06-24 15:20:36 -0400979 {
Jamie Madill8693bdb2017-09-02 15:32:14 -0400980 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
Shannon Woods53a94a82014-06-24 15:20:36 -0400981 }
982
Jamie Madill8693bdb2017-09-02 15:32:14 -0400983 if (mDrawFramebuffer && mDrawFramebuffer->detachTexture(context, texture))
Shannon Woods53a94a82014-06-24 15:20:36 -0400984 {
Jamie Madill8693bdb2017-09-02 15:32:14 -0400985 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
Shannon Woods53a94a82014-06-24 15:20:36 -0400986 }
987}
988
Jamie Madill4928b7c2017-06-20 12:57:39 -0400989void State::initializeZeroTextures(const Context *context, const TextureMap &zeroTextures)
Jamie Madille6382c32014-11-07 15:05:26 -0500990{
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800991 for (TextureType type : angle::AllEnums<TextureType>())
Jamie Madille6382c32014-11-07 15:05:26 -0500992 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800993 for (size_t textureUnit = 0; textureUnit < mSamplerTextures[type].size(); ++textureUnit)
Jamie Madille6382c32014-11-07 15:05:26 -0500994 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800995 mSamplerTextures[type][textureUnit].set(context, zeroTextures[type].get());
Jamie Madille6382c32014-11-07 15:05:26 -0500996 }
997 }
998}
999
Jamie Madill4928b7c2017-06-20 12:57:39 -04001000void State::setSamplerBinding(const Context *context, GLuint textureUnit, Sampler *sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001001{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001002 mSamplers[textureUnit].set(context, sampler);
Jamie Madill81c2e252017-09-09 23:32:46 -04001003 mDirtyBits.set(DIRTY_BIT_SAMPLER_BINDINGS);
1004 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Shannon Woods53a94a82014-06-24 15:20:36 -04001005}
1006
1007GLuint State::getSamplerId(GLuint textureUnit) const
1008{
Geoff Lang76b10c92014-09-05 16:28:14 -04001009 ASSERT(textureUnit < mSamplers.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001010 return mSamplers[textureUnit].id();
1011}
1012
1013Sampler *State::getSampler(GLuint textureUnit) const
1014{
1015 return mSamplers[textureUnit].get();
1016}
1017
Jamie Madill4928b7c2017-06-20 12:57:39 -04001018void State::detachSampler(const Context *context, GLuint sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001019{
1020 // [OpenGL ES 3.0.2] section 3.8.2 pages 123-124:
1021 // If a sampler object that is currently bound to one or more texture units is
1022 // deleted, it is as though BindSampler is called once for each texture unit to
1023 // which the sampler is bound, with unit set to the texture unit and sampler set to zero.
Jamie Madill81c2e252017-09-09 23:32:46 -04001024 for (BindingPointer<Sampler> &samplerBinding : mSamplers)
Shannon Woods53a94a82014-06-24 15:20:36 -04001025 {
Geoff Lang76b10c92014-09-05 16:28:14 -04001026 if (samplerBinding.id() == sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001027 {
Jamie Madill4928b7c2017-06-20 12:57:39 -04001028 samplerBinding.set(context, nullptr);
Jamie Madill81c2e252017-09-09 23:32:46 -04001029 mDirtyBits.set(DIRTY_BIT_SAMPLER_BINDINGS);
Shannon Woods53a94a82014-06-24 15:20:36 -04001030 }
1031 }
1032}
1033
Jamie Madill4928b7c2017-06-20 12:57:39 -04001034void State::setRenderbufferBinding(const Context *context, Renderbuffer *renderbuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001035{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001036 mRenderbuffer.set(context, renderbuffer);
Jamie Madill8693bdb2017-09-02 15:32:14 -04001037 mDirtyBits.set(DIRTY_BIT_RENDERBUFFER_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001038}
1039
1040GLuint State::getRenderbufferId() const
1041{
1042 return mRenderbuffer.id();
1043}
1044
Jamie Madilldfde6ab2016-06-09 07:07:18 -07001045Renderbuffer *State::getCurrentRenderbuffer() const
Shannon Woods53a94a82014-06-24 15:20:36 -04001046{
1047 return mRenderbuffer.get();
1048}
1049
Jamie Madilla02315b2017-02-23 14:14:47 -05001050void State::detachRenderbuffer(const Context *context, GLuint renderbuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001051{
1052 // [OpenGL ES 2.0.24] section 4.4 page 109:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001053 // If a renderbuffer that is currently bound to RENDERBUFFER is deleted, it is as though
1054 // BindRenderbuffer had been executed with the target RENDERBUFFER and name of zero.
Shannon Woods53a94a82014-06-24 15:20:36 -04001055
1056 if (mRenderbuffer.id() == renderbuffer)
1057 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001058 setRenderbufferBinding(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001059 }
1060
1061 // [OpenGL ES 2.0.24] section 4.4 page 111:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001062 // If a renderbuffer object is deleted while its image is attached to the currently bound
1063 // framebuffer, then it is as if FramebufferRenderbuffer had been called, with a renderbuffer of
1064 // 0, for each attachment point to which this image was attached in the currently bound
1065 // framebuffer.
Shannon Woods53a94a82014-06-24 15:20:36 -04001066
1067 Framebuffer *readFramebuffer = mReadFramebuffer;
1068 Framebuffer *drawFramebuffer = mDrawFramebuffer;
1069
Jamie Madill8693bdb2017-09-02 15:32:14 -04001070 if (readFramebuffer && readFramebuffer->detachRenderbuffer(context, renderbuffer))
Shannon Woods53a94a82014-06-24 15:20:36 -04001071 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001072 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
Shannon Woods53a94a82014-06-24 15:20:36 -04001073 }
1074
1075 if (drawFramebuffer && drawFramebuffer != readFramebuffer)
1076 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001077 if (drawFramebuffer->detachRenderbuffer(context, renderbuffer))
1078 {
1079 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
1080 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001081 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001082}
1083
1084void State::setReadFramebufferBinding(Framebuffer *framebuffer)
1085{
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001086 if (mReadFramebuffer == framebuffer)
1087 return;
1088
Shannon Woods53a94a82014-06-24 15:20:36 -04001089 mReadFramebuffer = framebuffer;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001090 mDirtyBits.set(DIRTY_BIT_READ_FRAMEBUFFER_BINDING);
1091
1092 if (mReadFramebuffer && mReadFramebuffer->hasAnyDirtyBit())
1093 {
1094 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
1095 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001096}
1097
1098void State::setDrawFramebufferBinding(Framebuffer *framebuffer)
1099{
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001100 if (mDrawFramebuffer == framebuffer)
1101 return;
1102
Shannon Woods53a94a82014-06-24 15:20:36 -04001103 mDrawFramebuffer = framebuffer;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001104 mDirtyBits.set(DIRTY_BIT_DRAW_FRAMEBUFFER_BINDING);
1105
1106 if (mDrawFramebuffer && mDrawFramebuffer->hasAnyDirtyBit())
1107 {
1108 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
1109 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001110}
1111
1112Framebuffer *State::getTargetFramebuffer(GLenum target) const
1113{
1114 switch (target)
1115 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001116 case GL_READ_FRAMEBUFFER_ANGLE:
1117 return mReadFramebuffer;
1118 case GL_DRAW_FRAMEBUFFER_ANGLE:
1119 case GL_FRAMEBUFFER:
1120 return mDrawFramebuffer;
1121 default:
1122 UNREACHABLE();
Yunchao Hef81ce4a2017-04-24 10:49:17 +08001123 return nullptr;
Shannon Woods53a94a82014-06-24 15:20:36 -04001124 }
1125}
1126
Jamie Madill51f40ec2016-06-15 14:06:00 -04001127Framebuffer *State::getReadFramebuffer() const
Shannon Woods53a94a82014-06-24 15:20:36 -04001128{
1129 return mReadFramebuffer;
1130}
1131
Jamie Madill51f40ec2016-06-15 14:06:00 -04001132Framebuffer *State::getDrawFramebuffer() const
Shannon Woods53a94a82014-06-24 15:20:36 -04001133{
1134 return mDrawFramebuffer;
1135}
1136
1137bool State::removeReadFramebufferBinding(GLuint framebuffer)
1138{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001139 if (mReadFramebuffer != nullptr && mReadFramebuffer->id() == framebuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001140 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001141 setReadFramebufferBinding(nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001142 return true;
1143 }
1144
1145 return false;
1146}
1147
1148bool State::removeDrawFramebufferBinding(GLuint framebuffer)
1149{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001150 if (mReadFramebuffer != nullptr && mDrawFramebuffer->id() == framebuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001151 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001152 setDrawFramebufferBinding(nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001153 return true;
1154 }
1155
1156 return false;
1157}
1158
1159void State::setVertexArrayBinding(VertexArray *vertexArray)
1160{
James Darpiniane8a93c62018-01-04 18:02:24 -08001161 if (mVertexArray == vertexArray)
1162 return;
1163 if (mVertexArray)
1164 mVertexArray->onBindingChanged(false);
Shannon Woods53a94a82014-06-24 15:20:36 -04001165 mVertexArray = vertexArray;
James Darpiniane8a93c62018-01-04 18:02:24 -08001166 if (vertexArray)
1167 vertexArray->onBindingChanged(true);
Jamie Madill0b9e9032015-08-17 11:51:52 +00001168 mDirtyBits.set(DIRTY_BIT_VERTEX_ARRAY_BINDING);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001169
1170 if (mVertexArray && mVertexArray->hasAnyDirtyBit())
1171 {
1172 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1173 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001174}
1175
1176GLuint State::getVertexArrayId() const
1177{
Yunchao He4f285442017-04-21 12:15:49 +08001178 ASSERT(mVertexArray != nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001179 return mVertexArray->id();
1180}
1181
1182VertexArray *State::getVertexArray() const
1183{
Yunchao He4f285442017-04-21 12:15:49 +08001184 ASSERT(mVertexArray != nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001185 return mVertexArray;
1186}
1187
1188bool State::removeVertexArrayBinding(GLuint vertexArray)
1189{
James Darpiniane8a93c62018-01-04 18:02:24 -08001190 if (mVertexArray && mVertexArray->id() == vertexArray)
Shannon Woods53a94a82014-06-24 15:20:36 -04001191 {
James Darpiniane8a93c62018-01-04 18:02:24 -08001192 mVertexArray->onBindingChanged(false);
Yunchao Hed7297bf2017-04-19 15:27:10 +08001193 mVertexArray = nullptr;
Jamie Madill0b9e9032015-08-17 11:51:52 +00001194 mDirtyBits.set(DIRTY_BIT_VERTEX_ARRAY_BINDING);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001195 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001196 return true;
1197 }
1198
1199 return false;
1200}
1201
Jamie Madill4928b7c2017-06-20 12:57:39 -04001202void State::bindVertexBuffer(const Context *context,
1203 GLuint bindingIndex,
Shao80957d92017-02-20 21:25:59 +08001204 Buffer *boundBuffer,
1205 GLintptr offset,
1206 GLsizei stride)
1207{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001208 getVertexArray()->bindVertexBuffer(context, bindingIndex, boundBuffer, offset, stride);
Shao80957d92017-02-20 21:25:59 +08001209 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1210}
1211
Shaodde78e82017-05-22 14:13:27 +08001212void State::setVertexAttribBinding(const Context *context, GLuint attribIndex, GLuint bindingIndex)
Shao80957d92017-02-20 21:25:59 +08001213{
Shaodde78e82017-05-22 14:13:27 +08001214 getVertexArray()->setVertexAttribBinding(context, attribIndex, bindingIndex);
Shao80957d92017-02-20 21:25:59 +08001215 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1216}
1217
1218void State::setVertexAttribFormat(GLuint attribIndex,
1219 GLint size,
1220 GLenum type,
1221 bool normalized,
1222 bool pureInteger,
1223 GLuint relativeOffset)
1224{
1225 getVertexArray()->setVertexAttribFormat(attribIndex, size, type, normalized, pureInteger,
1226 relativeOffset);
1227 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1228}
1229
1230void State::setVertexBindingDivisor(GLuint bindingIndex, GLuint divisor)
1231{
1232 getVertexArray()->setVertexBindingDivisor(bindingIndex, divisor);
1233 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1234}
1235
Jamie Madill6c1f6712017-02-14 19:08:04 -05001236void State::setProgram(const Context *context, Program *newProgram)
Shannon Woods53a94a82014-06-24 15:20:36 -04001237{
Geoff Lang7dd2e102014-11-10 15:19:26 -05001238 if (mProgram != newProgram)
Shannon Woods53a94a82014-06-24 15:20:36 -04001239 {
Geoff Lang7dd2e102014-11-10 15:19:26 -05001240 if (mProgram)
1241 {
Jamie Madill6c1f6712017-02-14 19:08:04 -05001242 mProgram->release(context);
Geoff Lang7dd2e102014-11-10 15:19:26 -05001243 }
1244
1245 mProgram = newProgram;
1246
1247 if (mProgram)
1248 {
1249 newProgram->addRef();
Jamie Madill81c2e252017-09-09 23:32:46 -04001250 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Geoff Lang7dd2e102014-11-10 15:19:26 -05001251 }
Jamie Madilla779b612017-07-24 11:46:05 -04001252 mDirtyBits.set(DIRTY_BIT_PROGRAM_EXECUTABLE);
1253 mDirtyBits.set(DIRTY_BIT_PROGRAM_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001254 }
1255}
1256
Geoff Lang7dd2e102014-11-10 15:19:26 -05001257Program *State::getProgram() const
Shannon Woods53a94a82014-06-24 15:20:36 -04001258{
Geoff Lang7dd2e102014-11-10 15:19:26 -05001259 return mProgram;
Shannon Woods53a94a82014-06-24 15:20:36 -04001260}
1261
Jamie Madill4928b7c2017-06-20 12:57:39 -04001262void State::setTransformFeedbackBinding(const Context *context,
1263 TransformFeedback *transformFeedback)
Shannon Woods53a94a82014-06-24 15:20:36 -04001264{
James Darpiniane8a93c62018-01-04 18:02:24 -08001265 if (transformFeedback == mTransformFeedback.get())
1266 return;
1267 if (mTransformFeedback.get())
1268 mTransformFeedback->onBindingChanged(false);
Jamie Madill4928b7c2017-06-20 12:57:39 -04001269 mTransformFeedback.set(context, transformFeedback);
James Darpiniane8a93c62018-01-04 18:02:24 -08001270 if (mTransformFeedback.get())
1271 mTransformFeedback->onBindingChanged(true);
Geoff Langded79232017-11-28 15:21:11 -05001272 mDirtyBits.set(DIRTY_BIT_TRANSFORM_FEEDBACK_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001273}
1274
1275TransformFeedback *State::getCurrentTransformFeedback() const
1276{
1277 return mTransformFeedback.get();
1278}
1279
Gregoire Payen de La Garanderie52742022015-02-04 14:55:39 +00001280bool State::isTransformFeedbackActiveUnpaused() const
1281{
Jamie Madill81c2e252017-09-09 23:32:46 -04001282 TransformFeedback *curTransformFeedback = getCurrentTransformFeedback();
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001283 return curTransformFeedback && curTransformFeedback->isActive() &&
1284 !curTransformFeedback->isPaused();
Gregoire Payen de La Garanderie52742022015-02-04 14:55:39 +00001285}
1286
Jamie Madill4928b7c2017-06-20 12:57:39 -04001287bool State::removeTransformFeedbackBinding(const Context *context, GLuint transformFeedback)
Shannon Woods53a94a82014-06-24 15:20:36 -04001288{
1289 if (mTransformFeedback.id() == transformFeedback)
1290 {
James Darpiniane8a93c62018-01-04 18:02:24 -08001291 if (mTransformFeedback.get())
1292 mTransformFeedback->onBindingChanged(false);
Jamie Madill4928b7c2017-06-20 12:57:39 -04001293 mTransformFeedback.set(context, nullptr);
Corentin Walleza2257da2016-04-19 16:43:12 -04001294 return true;
Shannon Woods53a94a82014-06-24 15:20:36 -04001295 }
Corentin Walleza2257da2016-04-19 16:43:12 -04001296
1297 return false;
Shannon Woods53a94a82014-06-24 15:20:36 -04001298}
1299
Yunchao Hea336b902017-08-02 16:05:21 +08001300void State::setProgramPipelineBinding(const Context *context, ProgramPipeline *pipeline)
1301{
1302 mProgramPipeline.set(context, pipeline);
1303}
1304
1305void State::detachProgramPipeline(const Context *context, GLuint pipeline)
1306{
1307 mProgramPipeline.set(context, nullptr);
1308}
1309
Olli Etuahobbf1c102016-06-28 13:31:33 +03001310bool State::isQueryActive(const GLenum type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001311{
Ian Ewell3ffd78b2016-01-22 16:09:42 -05001312 for (auto &iter : mActiveQueries)
Shannon Woods53a94a82014-06-24 15:20:36 -04001313 {
Olli Etuahobbf1c102016-06-28 13:31:33 +03001314 const Query *query = iter.second.get();
1315 if (query != nullptr && ActiveQueryType(query->getType()) == ActiveQueryType(type))
Ian Ewell3ffd78b2016-01-22 16:09:42 -05001316 {
1317 return true;
1318 }
1319 }
1320
1321 return false;
1322}
1323
1324bool State::isQueryActive(Query *query) const
1325{
1326 for (auto &iter : mActiveQueries)
1327 {
1328 if (iter.second.get() == query)
Shannon Woods53a94a82014-06-24 15:20:36 -04001329 {
1330 return true;
1331 }
1332 }
1333
1334 return false;
1335}
1336
Jamie Madill4928b7c2017-06-20 12:57:39 -04001337void State::setActiveQuery(const Context *context, GLenum target, Query *query)
Shannon Woods53a94a82014-06-24 15:20:36 -04001338{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001339 mActiveQueries[target].set(context, query);
Shannon Woods53a94a82014-06-24 15:20:36 -04001340}
1341
1342GLuint State::getActiveQueryId(GLenum target) const
1343{
1344 const Query *query = getActiveQuery(target);
1345 return (query ? query->id() : 0u);
1346}
1347
1348Query *State::getActiveQuery(GLenum target) const
1349{
Jamie Madill5864ac22015-01-12 14:43:07 -05001350 const auto it = mActiveQueries.find(target);
Shannon Woods53a94a82014-06-24 15:20:36 -04001351
Jamie Madill5864ac22015-01-12 14:43:07 -05001352 // All query types should already exist in the activeQueries map
1353 ASSERT(it != mActiveQueries.end());
1354
1355 return it->second.get();
Shannon Woods53a94a82014-06-24 15:20:36 -04001356}
1357
Corentin Wallez336129f2017-10-17 15:55:40 -04001358void State::setBufferBinding(const Context *context, BufferBinding target, Buffer *buffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001359{
Corentin Wallez336129f2017-10-17 15:55:40 -04001360 switch (target)
1361 {
1362 case BufferBinding::PixelPack:
James Darpiniane8a93c62018-01-04 18:02:24 -08001363 UpdateBufferBinding(context, &mBoundBuffers[target], buffer, target);
Corentin Wallez336129f2017-10-17 15:55:40 -04001364 mDirtyBits.set(DIRTY_BIT_PACK_BUFFER_BINDING);
1365 break;
1366 case BufferBinding::PixelUnpack:
James Darpiniane8a93c62018-01-04 18:02:24 -08001367 UpdateBufferBinding(context, &mBoundBuffers[target], buffer, target);
Corentin Wallez336129f2017-10-17 15:55:40 -04001368 mDirtyBits.set(DIRTY_BIT_UNPACK_BUFFER_BINDING);
1369 break;
1370 case BufferBinding::DrawIndirect:
James Darpiniane8a93c62018-01-04 18:02:24 -08001371 UpdateBufferBinding(context, &mBoundBuffers[target], buffer, target);
Corentin Wallez336129f2017-10-17 15:55:40 -04001372 mDirtyBits.set(DIRTY_BIT_DRAW_INDIRECT_BUFFER_BINDING);
1373 break;
Qin Jiajiaa98a2812017-11-30 18:12:06 +08001374 case BufferBinding::DispatchIndirect:
James Darpiniane8a93c62018-01-04 18:02:24 -08001375 UpdateBufferBinding(context, &mBoundBuffers[target], buffer, target);
Qin Jiajiaa98a2812017-11-30 18:12:06 +08001376 mDirtyBits.set(DIRTY_BIT_DISPATCH_INDIRECT_BUFFER_BINDING);
1377 break;
Corentin Wallez336129f2017-10-17 15:55:40 -04001378 case BufferBinding::ElementArray:
1379 getVertexArray()->setElementArrayBuffer(context, buffer);
1380 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1381 break;
Xinghua Cao10a4d432017-11-28 14:46:26 +08001382 case BufferBinding::ShaderStorage:
James Darpiniane8a93c62018-01-04 18:02:24 -08001383 UpdateBufferBinding(context, &mBoundBuffers[target], buffer, target);
Xinghua Cao10a4d432017-11-28 14:46:26 +08001384 mDirtyBits.set(DIRTY_BIT_SHADER_STORAGE_BUFFER_BINDING);
1385 break;
Corentin Wallez336129f2017-10-17 15:55:40 -04001386 default:
James Darpiniane8a93c62018-01-04 18:02:24 -08001387 UpdateBufferBinding(context, &mBoundBuffers[target], buffer, target);
Corentin Wallez336129f2017-10-17 15:55:40 -04001388 break;
1389 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001390}
James Darpiniane8a93c62018-01-04 18:02:24 -08001391
Corentin Wallez336129f2017-10-17 15:55:40 -04001392void State::setIndexedBufferBinding(const Context *context,
1393 BufferBinding target,
1394 GLuint index,
1395 Buffer *buffer,
1396 GLintptr offset,
1397 GLsizeiptr size)
Jiajia Qin9d7d0b12016-11-29 16:30:31 +08001398{
Corentin Wallez336129f2017-10-17 15:55:40 -04001399 setBufferBinding(context, target, buffer);
Jiajia Qin9d7d0b12016-11-29 16:30:31 +08001400
Corentin Wallez336129f2017-10-17 15:55:40 -04001401 switch (target)
1402 {
1403 case BufferBinding::TransformFeedback:
1404 mTransformFeedback->bindIndexedBuffer(context, index, buffer, offset, size);
James Darpiniane8a93c62018-01-04 18:02:24 -08001405 setBufferBinding(context, target, buffer);
Corentin Wallez336129f2017-10-17 15:55:40 -04001406 break;
1407 case BufferBinding::Uniform:
James Darpiniane8a93c62018-01-04 18:02:24 -08001408 UpdateBufferBinding(context, &mUniformBuffers[index], buffer, target, offset, size);
Jamie Madillf4141212017-12-12 15:08:07 -05001409 mDirtyBits.set(DIRTY_BIT_UNIFORM_BUFFER_BINDINGS);
Corentin Wallez336129f2017-10-17 15:55:40 -04001410 break;
1411 case BufferBinding::AtomicCounter:
James Darpiniane8a93c62018-01-04 18:02:24 -08001412 UpdateBufferBinding(context, &mAtomicCounterBuffers[index], buffer, target, offset,
1413 size);
Corentin Wallez336129f2017-10-17 15:55:40 -04001414 break;
1415 case BufferBinding::ShaderStorage:
James Darpiniane8a93c62018-01-04 18:02:24 -08001416 UpdateBufferBinding(context, &mShaderStorageBuffers[index], buffer, target, offset,
1417 size);
Corentin Wallez336129f2017-10-17 15:55:40 -04001418 break;
1419 default:
1420 UNREACHABLE();
1421 break;
1422 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001423}
1424
Geoff Lang5d124a62015-09-15 13:03:27 -04001425const OffsetBindingPointer<Buffer> &State::getIndexedUniformBuffer(size_t index) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001426{
Shannon Woodsf3acaf92014-09-23 18:07:11 -04001427 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
Geoff Lang5d124a62015-09-15 13:03:27 -04001428 return mUniformBuffers[index];
Gregoire Payen de La Garanderie68694e92015-03-24 14:03:37 +00001429}
1430
Jiajia Qin6eafb042016-12-27 17:04:07 +08001431const OffsetBindingPointer<Buffer> &State::getIndexedAtomicCounterBuffer(size_t index) const
1432{
1433 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
1434 return mAtomicCounterBuffers[index];
1435}
1436
Jiajia Qinf546e7d2017-03-27 14:12:59 +08001437const OffsetBindingPointer<Buffer> &State::getIndexedShaderStorageBuffer(size_t index) const
1438{
1439 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
1440 return mShaderStorageBuffers[index];
1441}
1442
Corentin Wallez336129f2017-10-17 15:55:40 -04001443Buffer *State::getTargetBuffer(BufferBinding target) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001444{
1445 switch (target)
1446 {
Corentin Wallez336129f2017-10-17 15:55:40 -04001447 case BufferBinding::ElementArray:
1448 return getVertexArray()->getElementArrayBuffer().get();
Corentin Wallez336129f2017-10-17 15:55:40 -04001449 default:
1450 return mBoundBuffers[target].get();
Shannon Woods53a94a82014-06-24 15:20:36 -04001451 }
1452}
1453
James Darpinian4d9d4832018-03-13 12:43:28 -07001454void State::detachBuffer(const Context *context, const Buffer *buffer)
Yuly Novikov5807a532015-12-03 13:01:22 -05001455{
James Darpinian4d9d4832018-03-13 12:43:28 -07001456 if (!buffer->isBound())
1457 {
1458 return;
1459 }
1460 GLuint bufferName = buffer->id();
James Darpiniane8a93c62018-01-04 18:02:24 -08001461 for (auto target : angle::AllEnums<BufferBinding>())
Yuly Novikov5807a532015-12-03 13:01:22 -05001462 {
James Darpiniane8a93c62018-01-04 18:02:24 -08001463 if (mBoundBuffers[target].id() == bufferName)
Yuly Novikov5807a532015-12-03 13:01:22 -05001464 {
James Darpiniane8a93c62018-01-04 18:02:24 -08001465 UpdateBufferBinding(context, &mBoundBuffers[target], nullptr, target);
Yuly Novikov5807a532015-12-03 13:01:22 -05001466 }
1467 }
1468
1469 TransformFeedback *curTransformFeedback = getCurrentTransformFeedback();
1470 if (curTransformFeedback)
1471 {
Jamie Madill4928b7c2017-06-20 12:57:39 -04001472 curTransformFeedback->detachBuffer(context, bufferName);
Yuly Novikov5807a532015-12-03 13:01:22 -05001473 }
1474
Jamie Madill4928b7c2017-06-20 12:57:39 -04001475 getVertexArray()->detachBuffer(context, bufferName);
James Darpiniane8a93c62018-01-04 18:02:24 -08001476
1477 for (auto &buf : mUniformBuffers)
1478 {
1479 if (buf.id() == bufferName)
1480 {
1481 UpdateBufferBinding(context, &buf, nullptr, BufferBinding::Uniform);
1482 }
1483 }
1484
1485 for (auto &buf : mAtomicCounterBuffers)
1486 {
1487 if (buf.id() == bufferName)
1488 {
1489 UpdateBufferBinding(context, &buf, nullptr, BufferBinding::AtomicCounter);
1490 }
1491 }
1492
1493 for (auto &buf : mShaderStorageBuffers)
1494 {
1495 if (buf.id() == bufferName)
1496 {
1497 UpdateBufferBinding(context, &buf, nullptr, BufferBinding::ShaderStorage);
1498 }
1499 }
Yuly Novikov5807a532015-12-03 13:01:22 -05001500}
1501
Shannon Woods53a94a82014-06-24 15:20:36 -04001502void State::setEnableVertexAttribArray(unsigned int attribNum, bool enabled)
1503{
1504 getVertexArray()->enableAttribute(attribNum, enabled);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001505 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001506}
1507
1508void State::setVertexAttribf(GLuint index, const GLfloat values[4])
1509{
Shannon Woods23e05002014-09-22 19:07:27 -04001510 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001511 mVertexAttribCurrentValues[index].setFloatValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001512 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1513 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001514 mCurrentValuesTypeMask.setIndex(GL_FLOAT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001515}
1516
1517void State::setVertexAttribu(GLuint index, const GLuint values[4])
1518{
Shannon Woods23e05002014-09-22 19:07:27 -04001519 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001520 mVertexAttribCurrentValues[index].setUnsignedIntValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001521 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1522 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001523 mCurrentValuesTypeMask.setIndex(GL_UNSIGNED_INT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001524}
1525
1526void State::setVertexAttribi(GLuint index, const GLint values[4])
1527{
Shannon Woods23e05002014-09-22 19:07:27 -04001528 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001529 mVertexAttribCurrentValues[index].setIntValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001530 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1531 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001532 mCurrentValuesTypeMask.setIndex(GL_INT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001533}
1534
Shaodde78e82017-05-22 14:13:27 +08001535void State::setVertexAttribPointer(const Context *context,
1536 unsigned int attribNum,
1537 Buffer *boundBuffer,
1538 GLint size,
1539 GLenum type,
1540 bool normalized,
1541 bool pureInteger,
1542 GLsizei stride,
1543 const void *pointer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001544{
Shaodde78e82017-05-22 14:13:27 +08001545 getVertexArray()->setVertexAttribPointer(context, attribNum, boundBuffer, size, type,
1546 normalized, pureInteger, stride, pointer);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001547 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Jamie Madill0b9e9032015-08-17 11:51:52 +00001548}
1549
Shaodde78e82017-05-22 14:13:27 +08001550void State::setVertexAttribDivisor(const Context *context, GLuint index, GLuint divisor)
Jamie Madill0b9e9032015-08-17 11:51:52 +00001551{
Shaodde78e82017-05-22 14:13:27 +08001552 getVertexArray()->setVertexAttribDivisor(context, index, divisor);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001553 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001554}
1555
Jamie Madill6de51852017-04-12 09:53:01 -04001556const VertexAttribCurrentValueData &State::getVertexAttribCurrentValue(size_t attribNum) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001557{
Jamie Madill6de51852017-04-12 09:53:01 -04001558 ASSERT(attribNum < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001559 return mVertexAttribCurrentValues[attribNum];
1560}
1561
Jamie Madillcac94a92017-11-10 10:09:32 -05001562const std::vector<VertexAttribCurrentValueData> &State::getVertexAttribCurrentValues() const
1563{
1564 return mVertexAttribCurrentValues;
1565}
1566
Shannon Woods53a94a82014-06-24 15:20:36 -04001567const void *State::getVertexAttribPointer(unsigned int attribNum) const
1568{
1569 return getVertexArray()->getVertexAttribute(attribNum).pointer;
1570}
1571
1572void State::setPackAlignment(GLint alignment)
1573{
1574 mPack.alignment = alignment;
Jamie Madillc67323a2017-11-02 23:11:41 -04001575 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001576}
1577
1578GLint State::getPackAlignment() const
1579{
1580 return mPack.alignment;
1581}
1582
1583void State::setPackReverseRowOrder(bool reverseRowOrder)
1584{
1585 mPack.reverseRowOrder = reverseRowOrder;
Jamie Madillc67323a2017-11-02 23:11:41 -04001586 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001587}
1588
1589bool State::getPackReverseRowOrder() const
1590{
1591 return mPack.reverseRowOrder;
1592}
1593
Minmin Gongadff67b2015-10-14 10:34:45 -04001594void State::setPackRowLength(GLint rowLength)
1595{
1596 mPack.rowLength = rowLength;
Jamie Madillc67323a2017-11-02 23:11:41 -04001597 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001598}
1599
1600GLint State::getPackRowLength() const
1601{
1602 return mPack.rowLength;
1603}
1604
1605void State::setPackSkipRows(GLint skipRows)
1606{
1607 mPack.skipRows = skipRows;
Jamie Madillc67323a2017-11-02 23:11:41 -04001608 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001609}
1610
1611GLint State::getPackSkipRows() const
1612{
1613 return mPack.skipRows;
1614}
1615
1616void State::setPackSkipPixels(GLint skipPixels)
1617{
1618 mPack.skipPixels = skipPixels;
Jamie Madillc67323a2017-11-02 23:11:41 -04001619 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001620}
1621
1622GLint State::getPackSkipPixels() const
1623{
1624 return mPack.skipPixels;
1625}
1626
Shannon Woods53a94a82014-06-24 15:20:36 -04001627const PixelPackState &State::getPackState() const
1628{
1629 return mPack;
1630}
1631
Jamie Madill87de3622015-03-16 10:41:44 -04001632PixelPackState &State::getPackState()
1633{
1634 return mPack;
1635}
1636
Shannon Woods53a94a82014-06-24 15:20:36 -04001637void State::setUnpackAlignment(GLint alignment)
1638{
1639 mUnpack.alignment = alignment;
Jamie Madillc67323a2017-11-02 23:11:41 -04001640 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001641}
1642
1643GLint State::getUnpackAlignment() const
1644{
1645 return mUnpack.alignment;
1646}
1647
Minmin Gongb8aee3b2015-01-27 14:42:36 -08001648void State::setUnpackRowLength(GLint rowLength)
1649{
1650 mUnpack.rowLength = rowLength;
Jamie Madillc67323a2017-11-02 23:11:41 -04001651 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongb8aee3b2015-01-27 14:42:36 -08001652}
1653
1654GLint State::getUnpackRowLength() const
1655{
1656 return mUnpack.rowLength;
1657}
1658
Minmin Gongadff67b2015-10-14 10:34:45 -04001659void State::setUnpackImageHeight(GLint imageHeight)
1660{
1661 mUnpack.imageHeight = imageHeight;
Jamie Madillc67323a2017-11-02 23:11:41 -04001662 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001663}
1664
1665GLint State::getUnpackImageHeight() const
1666{
1667 return mUnpack.imageHeight;
1668}
1669
1670void State::setUnpackSkipImages(GLint skipImages)
1671{
1672 mUnpack.skipImages = skipImages;
Jamie Madillc67323a2017-11-02 23:11:41 -04001673 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001674}
1675
1676GLint State::getUnpackSkipImages() const
1677{
1678 return mUnpack.skipImages;
1679}
1680
1681void State::setUnpackSkipRows(GLint skipRows)
1682{
1683 mUnpack.skipRows = skipRows;
Jamie Madillc67323a2017-11-02 23:11:41 -04001684 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001685}
1686
1687GLint State::getUnpackSkipRows() const
1688{
1689 return mUnpack.skipRows;
1690}
1691
1692void State::setUnpackSkipPixels(GLint skipPixels)
1693{
1694 mUnpack.skipPixels = skipPixels;
Jamie Madillc67323a2017-11-02 23:11:41 -04001695 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001696}
1697
1698GLint State::getUnpackSkipPixels() const
1699{
1700 return mUnpack.skipPixels;
1701}
1702
Shannon Woods53a94a82014-06-24 15:20:36 -04001703const PixelUnpackState &State::getUnpackState() const
1704{
1705 return mUnpack;
1706}
1707
Jamie Madill67102f02015-03-16 10:41:42 -04001708PixelUnpackState &State::getUnpackState()
1709{
1710 return mUnpack;
1711}
1712
Geoff Lang70d0f492015-12-10 17:45:46 -05001713const Debug &State::getDebug() const
1714{
1715 return mDebug;
1716}
1717
1718Debug &State::getDebug()
1719{
1720 return mDebug;
1721}
1722
Sami Väisänena797e062016-05-12 15:23:40 +03001723void State::setCoverageModulation(GLenum components)
1724{
1725 mCoverageModulation = components;
1726 mDirtyBits.set(DIRTY_BIT_COVERAGE_MODULATION);
1727}
1728
1729GLenum State::getCoverageModulation() const
1730{
1731 return mCoverageModulation;
1732}
1733
Sami Väisänene45e53b2016-05-25 10:36:04 +03001734void State::loadPathRenderingMatrix(GLenum matrixMode, const GLfloat *matrix)
1735{
1736 if (matrixMode == GL_PATH_MODELVIEW_CHROMIUM)
1737 {
1738 memcpy(mPathMatrixMV, matrix, 16 * sizeof(GLfloat));
1739 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING_MATRIX_MV);
1740 }
1741 else if (matrixMode == GL_PATH_PROJECTION_CHROMIUM)
1742 {
1743 memcpy(mPathMatrixProj, matrix, 16 * sizeof(GLfloat));
1744 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING_MATRIX_PROJ);
1745 }
1746 else
1747 {
1748 UNREACHABLE();
1749 }
1750}
1751
1752const GLfloat *State::getPathRenderingMatrix(GLenum which) const
1753{
1754 if (which == GL_PATH_MODELVIEW_MATRIX_CHROMIUM)
1755 {
1756 return mPathMatrixMV;
1757 }
1758 else if (which == GL_PATH_PROJECTION_MATRIX_CHROMIUM)
1759 {
1760 return mPathMatrixProj;
1761 }
1762
1763 UNREACHABLE();
1764 return nullptr;
1765}
1766
1767void State::setPathStencilFunc(GLenum func, GLint ref, GLuint mask)
1768{
1769 mPathStencilFunc = func;
1770 mPathStencilRef = ref;
1771 mPathStencilMask = mask;
1772 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING_STENCIL_STATE);
1773}
1774
1775GLenum State::getPathStencilFunc() const
1776{
1777 return mPathStencilFunc;
1778}
1779
1780GLint State::getPathStencilRef() const
1781{
1782 return mPathStencilRef;
1783}
1784
1785GLuint State::getPathStencilMask() const
1786{
1787 return mPathStencilMask;
1788}
1789
Geoff Lang1d2c41d2016-10-19 16:14:46 -07001790void State::setFramebufferSRGB(bool sRGB)
1791{
1792 mFramebufferSRGB = sRGB;
1793 mDirtyBits.set(DIRTY_BIT_FRAMEBUFFER_SRGB);
1794}
1795
1796bool State::getFramebufferSRGB() const
1797{
1798 return mFramebufferSRGB;
1799}
1800
Shannon Woods53a94a82014-06-24 15:20:36 -04001801void State::getBooleanv(GLenum pname, GLboolean *params)
1802{
1803 switch (pname)
1804 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001805 case GL_SAMPLE_COVERAGE_INVERT:
1806 *params = mSampleCoverageInvert;
1807 break;
1808 case GL_DEPTH_WRITEMASK:
1809 *params = mDepthStencil.depthMask;
1810 break;
1811 case GL_COLOR_WRITEMASK:
1812 params[0] = mBlend.colorMaskRed;
1813 params[1] = mBlend.colorMaskGreen;
1814 params[2] = mBlend.colorMaskBlue;
1815 params[3] = mBlend.colorMaskAlpha;
1816 break;
1817 case GL_CULL_FACE:
1818 *params = mRasterizer.cullFace;
1819 break;
1820 case GL_POLYGON_OFFSET_FILL:
1821 *params = mRasterizer.polygonOffsetFill;
1822 break;
1823 case GL_SAMPLE_ALPHA_TO_COVERAGE:
1824 *params = mBlend.sampleAlphaToCoverage;
1825 break;
1826 case GL_SAMPLE_COVERAGE:
1827 *params = mSampleCoverage;
1828 break;
1829 case GL_SAMPLE_MASK:
1830 *params = mSampleMask;
1831 break;
1832 case GL_SCISSOR_TEST:
1833 *params = mScissorTest;
1834 break;
1835 case GL_STENCIL_TEST:
1836 *params = mDepthStencil.stencilTest;
1837 break;
1838 case GL_DEPTH_TEST:
1839 *params = mDepthStencil.depthTest;
1840 break;
1841 case GL_BLEND:
1842 *params = mBlend.blend;
1843 break;
1844 case GL_DITHER:
1845 *params = mBlend.dither;
1846 break;
1847 case GL_TRANSFORM_FEEDBACK_ACTIVE:
1848 *params = getCurrentTransformFeedback()->isActive() ? GL_TRUE : GL_FALSE;
1849 break;
1850 case GL_TRANSFORM_FEEDBACK_PAUSED:
1851 *params = getCurrentTransformFeedback()->isPaused() ? GL_TRUE : GL_FALSE;
1852 break;
1853 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
1854 *params = mPrimitiveRestart;
1855 break;
1856 case GL_RASTERIZER_DISCARD:
1857 *params = isRasterizerDiscardEnabled() ? GL_TRUE : GL_FALSE;
1858 break;
1859 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
1860 *params = mDebug.isOutputSynchronous() ? GL_TRUE : GL_FALSE;
1861 break;
1862 case GL_DEBUG_OUTPUT:
1863 *params = mDebug.isOutputEnabled() ? GL_TRUE : GL_FALSE;
1864 break;
1865 case GL_MULTISAMPLE_EXT:
1866 *params = mMultiSampling;
1867 break;
1868 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
1869 *params = mSampleAlphaToOne;
1870 break;
1871 case GL_BIND_GENERATES_RESOURCE_CHROMIUM:
1872 *params = isBindGeneratesResourceEnabled() ? GL_TRUE : GL_FALSE;
1873 break;
1874 case GL_CLIENT_ARRAYS_ANGLE:
1875 *params = areClientArraysEnabled() ? GL_TRUE : GL_FALSE;
1876 break;
1877 case GL_FRAMEBUFFER_SRGB_EXT:
1878 *params = getFramebufferSRGB() ? GL_TRUE : GL_FALSE;
1879 break;
1880 case GL_ROBUST_RESOURCE_INITIALIZATION_ANGLE:
1881 *params = mRobustResourceInit ? GL_TRUE : GL_FALSE;
1882 break;
1883 case GL_PROGRAM_CACHE_ENABLED_ANGLE:
1884 *params = mProgramBinaryCacheEnabled ? GL_TRUE : GL_FALSE;
1885 break;
Jamie Madillc43be722017-07-13 16:22:14 -04001886
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001887 default:
1888 UNREACHABLE();
1889 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04001890 }
1891}
1892
1893void State::getFloatv(GLenum pname, GLfloat *params)
1894{
1895 // Please note: DEPTH_CLEAR_VALUE is included in our internal getFloatv implementation
1896 // because it is stored as a float, despite the fact that the GL ES 2.0 spec names
1897 // GetIntegerv as its native query function. As it would require conversion in any
1898 // case, this should make no difference to the calling application.
1899 switch (pname)
1900 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001901 case GL_LINE_WIDTH:
1902 *params = mLineWidth;
1903 break;
1904 case GL_SAMPLE_COVERAGE_VALUE:
1905 *params = mSampleCoverageValue;
1906 break;
1907 case GL_DEPTH_CLEAR_VALUE:
1908 *params = mDepthClearValue;
1909 break;
1910 case GL_POLYGON_OFFSET_FACTOR:
1911 *params = mRasterizer.polygonOffsetFactor;
1912 break;
1913 case GL_POLYGON_OFFSET_UNITS:
1914 *params = mRasterizer.polygonOffsetUnits;
1915 break;
1916 case GL_DEPTH_RANGE:
1917 params[0] = mNearZ;
1918 params[1] = mFarZ;
1919 break;
1920 case GL_COLOR_CLEAR_VALUE:
1921 params[0] = mColorClearValue.red;
1922 params[1] = mColorClearValue.green;
1923 params[2] = mColorClearValue.blue;
1924 params[3] = mColorClearValue.alpha;
1925 break;
1926 case GL_BLEND_COLOR:
1927 params[0] = mBlendColor.red;
1928 params[1] = mBlendColor.green;
1929 params[2] = mBlendColor.blue;
1930 params[3] = mBlendColor.alpha;
1931 break;
1932 case GL_MULTISAMPLE_EXT:
1933 *params = static_cast<GLfloat>(mMultiSampling);
1934 break;
1935 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
1936 *params = static_cast<GLfloat>(mSampleAlphaToOne);
1937 break;
1938 case GL_COVERAGE_MODULATION_CHROMIUM:
1939 params[0] = static_cast<GLfloat>(mCoverageModulation);
1940 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -07001941 case GL_ALPHA_TEST_REF:
1942 *params = mGLES1State.mAlphaTestRef;
1943 break;
Lingfeng Yanga43994c2018-03-29 07:21:41 -07001944 case GL_CURRENT_COLOR:
1945 {
1946 const auto &color = mGLES1State.mCurrentColor;
1947 params[0] = color.red;
1948 params[1] = color.green;
1949 params[2] = color.blue;
1950 params[3] = color.alpha;
1951 break;
1952 }
Lingfeng Yang5a7e61b2018-03-29 16:50:32 -07001953 case GL_CURRENT_NORMAL:
1954 {
1955 const auto &normal = mGLES1State.mCurrentNormal;
1956 params[0] = normal[0];
1957 params[1] = normal[1];
1958 params[2] = normal[2];
1959 break;
1960 }
Lingfeng Yang038dd532018-03-29 17:31:52 -07001961 case GL_CURRENT_TEXTURE_COORDS:
1962 {
1963 const auto &texcoord = mGLES1State.mCurrentTextureCoords[mActiveSampler];
1964 params[0] = texcoord.s;
1965 params[1] = texcoord.t;
1966 params[2] = texcoord.r;
1967 params[3] = texcoord.q;
1968 break;
1969 }
Lingfeng Yang3a41af62018-04-09 07:28:56 -07001970 case GL_MODELVIEW_MATRIX:
1971 memcpy(params, mGLES1State.mModelviewMatrices.back().data(), 16 * sizeof(GLfloat));
1972 break;
1973 case GL_PROJECTION_MATRIX:
1974 memcpy(params, mGLES1State.mProjectionMatrices.back().data(), 16 * sizeof(GLfloat));
1975 break;
1976 case GL_TEXTURE_MATRIX:
1977 memcpy(params, mGLES1State.mTextureMatrices[mActiveSampler].back().data(),
1978 16 * sizeof(GLfloat));
1979 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001980 default:
1981 UNREACHABLE();
1982 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04001983 }
1984}
1985
Jamie Madille98b1b52018-03-08 09:47:23 -05001986Error State::getIntegerv(const Context *context, GLenum pname, GLint *params)
Shannon Woods53a94a82014-06-24 15:20:36 -04001987{
1988 if (pname >= GL_DRAW_BUFFER0_EXT && pname <= GL_DRAW_BUFFER15_EXT)
1989 {
1990 unsigned int colorAttachment = (pname - GL_DRAW_BUFFER0_EXT);
Shannon Woods2df6a602014-09-26 16:12:07 -04001991 ASSERT(colorAttachment < mMaxDrawBuffers);
Shannon Woods53a94a82014-06-24 15:20:36 -04001992 Framebuffer *framebuffer = mDrawFramebuffer;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001993 *params = framebuffer->getDrawBufferState(colorAttachment);
Jamie Madille98b1b52018-03-08 09:47:23 -05001994 return NoError();
Shannon Woods53a94a82014-06-24 15:20:36 -04001995 }
1996
1997 // Please note: DEPTH_CLEAR_VALUE is not included in our internal getIntegerv implementation
1998 // because it is stored as a float, despite the fact that the GL ES 2.0 spec names
1999 // GetIntegerv as its native query function. As it would require conversion in any
2000 // case, this should make no difference to the calling application. You may find it in
2001 // State::getFloatv.
2002 switch (pname)
2003 {
Corentin Wallez336129f2017-10-17 15:55:40 -04002004 case GL_ARRAY_BUFFER_BINDING:
2005 *params = mBoundBuffers[BufferBinding::Array].id();
2006 break;
2007 case GL_DRAW_INDIRECT_BUFFER_BINDING:
2008 *params = mBoundBuffers[BufferBinding::DrawIndirect].id();
2009 break;
2010 case GL_ELEMENT_ARRAY_BUFFER_BINDING:
2011 *params = getVertexArray()->getElementArrayBuffer().id();
2012 break;
Jamie Madill690c8eb2018-03-12 15:20:03 -04002013 case GL_DRAW_FRAMEBUFFER_BINDING:
2014 static_assert(GL_DRAW_FRAMEBUFFER_BINDING == GL_DRAW_FRAMEBUFFER_BINDING_ANGLE,
2015 "Enum mismatch");
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002016 *params = mDrawFramebuffer->id();
2017 break;
Jamie Madill690c8eb2018-03-12 15:20:03 -04002018 case GL_READ_FRAMEBUFFER_BINDING:
2019 static_assert(GL_READ_FRAMEBUFFER_BINDING == GL_READ_FRAMEBUFFER_BINDING_ANGLE,
2020 "Enum mismatch");
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002021 *params = mReadFramebuffer->id();
2022 break;
2023 case GL_RENDERBUFFER_BINDING:
2024 *params = mRenderbuffer.id();
2025 break;
2026 case GL_VERTEX_ARRAY_BINDING:
2027 *params = mVertexArray->id();
2028 break;
2029 case GL_CURRENT_PROGRAM:
2030 *params = mProgram ? mProgram->id() : 0;
2031 break;
2032 case GL_PACK_ALIGNMENT:
2033 *params = mPack.alignment;
2034 break;
2035 case GL_PACK_REVERSE_ROW_ORDER_ANGLE:
2036 *params = mPack.reverseRowOrder;
2037 break;
2038 case GL_PACK_ROW_LENGTH:
2039 *params = mPack.rowLength;
2040 break;
2041 case GL_PACK_SKIP_ROWS:
2042 *params = mPack.skipRows;
2043 break;
2044 case GL_PACK_SKIP_PIXELS:
2045 *params = mPack.skipPixels;
2046 break;
2047 case GL_UNPACK_ALIGNMENT:
2048 *params = mUnpack.alignment;
2049 break;
2050 case GL_UNPACK_ROW_LENGTH:
2051 *params = mUnpack.rowLength;
2052 break;
2053 case GL_UNPACK_IMAGE_HEIGHT:
2054 *params = mUnpack.imageHeight;
2055 break;
2056 case GL_UNPACK_SKIP_IMAGES:
2057 *params = mUnpack.skipImages;
2058 break;
2059 case GL_UNPACK_SKIP_ROWS:
2060 *params = mUnpack.skipRows;
2061 break;
2062 case GL_UNPACK_SKIP_PIXELS:
2063 *params = mUnpack.skipPixels;
2064 break;
2065 case GL_GENERATE_MIPMAP_HINT:
2066 *params = mGenerateMipmapHint;
2067 break;
2068 case GL_FRAGMENT_SHADER_DERIVATIVE_HINT_OES:
2069 *params = mFragmentShaderDerivativeHint;
2070 break;
2071 case GL_ACTIVE_TEXTURE:
2072 *params = (static_cast<GLint>(mActiveSampler) + GL_TEXTURE0);
2073 break;
2074 case GL_STENCIL_FUNC:
2075 *params = mDepthStencil.stencilFunc;
2076 break;
2077 case GL_STENCIL_REF:
2078 *params = mStencilRef;
2079 break;
2080 case GL_STENCIL_VALUE_MASK:
2081 *params = CastMaskValue(context, mDepthStencil.stencilMask);
2082 break;
2083 case GL_STENCIL_BACK_FUNC:
2084 *params = mDepthStencil.stencilBackFunc;
2085 break;
2086 case GL_STENCIL_BACK_REF:
2087 *params = mStencilBackRef;
2088 break;
2089 case GL_STENCIL_BACK_VALUE_MASK:
2090 *params = CastMaskValue(context, mDepthStencil.stencilBackMask);
2091 break;
2092 case GL_STENCIL_FAIL:
2093 *params = mDepthStencil.stencilFail;
2094 break;
2095 case GL_STENCIL_PASS_DEPTH_FAIL:
2096 *params = mDepthStencil.stencilPassDepthFail;
2097 break;
2098 case GL_STENCIL_PASS_DEPTH_PASS:
2099 *params = mDepthStencil.stencilPassDepthPass;
2100 break;
2101 case GL_STENCIL_BACK_FAIL:
2102 *params = mDepthStencil.stencilBackFail;
2103 break;
2104 case GL_STENCIL_BACK_PASS_DEPTH_FAIL:
2105 *params = mDepthStencil.stencilBackPassDepthFail;
2106 break;
2107 case GL_STENCIL_BACK_PASS_DEPTH_PASS:
2108 *params = mDepthStencil.stencilBackPassDepthPass;
2109 break;
2110 case GL_DEPTH_FUNC:
2111 *params = mDepthStencil.depthFunc;
2112 break;
2113 case GL_BLEND_SRC_RGB:
2114 *params = mBlend.sourceBlendRGB;
2115 break;
2116 case GL_BLEND_SRC_ALPHA:
2117 *params = mBlend.sourceBlendAlpha;
2118 break;
2119 case GL_BLEND_DST_RGB:
2120 *params = mBlend.destBlendRGB;
2121 break;
2122 case GL_BLEND_DST_ALPHA:
2123 *params = mBlend.destBlendAlpha;
2124 break;
2125 case GL_BLEND_EQUATION_RGB:
2126 *params = mBlend.blendEquationRGB;
2127 break;
2128 case GL_BLEND_EQUATION_ALPHA:
2129 *params = mBlend.blendEquationAlpha;
2130 break;
2131 case GL_STENCIL_WRITEMASK:
2132 *params = CastMaskValue(context, mDepthStencil.stencilWritemask);
2133 break;
2134 case GL_STENCIL_BACK_WRITEMASK:
2135 *params = CastMaskValue(context, mDepthStencil.stencilBackWritemask);
2136 break;
2137 case GL_STENCIL_CLEAR_VALUE:
2138 *params = mStencilClearValue;
2139 break;
2140 case GL_IMPLEMENTATION_COLOR_READ_TYPE:
Jamie Madill690c8eb2018-03-12 15:20:03 -04002141 ANGLE_TRY(mReadFramebuffer->getImplementationColorReadType(
2142 context, reinterpret_cast<GLenum *>(params)));
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002143 break;
2144 case GL_IMPLEMENTATION_COLOR_READ_FORMAT:
Jamie Madill690c8eb2018-03-12 15:20:03 -04002145 ANGLE_TRY(mReadFramebuffer->getImplementationColorReadFormat(
2146 context, reinterpret_cast<GLenum *>(params)));
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002147 break;
2148 case GL_SAMPLE_BUFFERS:
2149 case GL_SAMPLES:
Shannon Woods53a94a82014-06-24 15:20:36 -04002150 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002151 Framebuffer *framebuffer = mDrawFramebuffer;
Jamie Madill427064d2018-04-13 16:20:34 -04002152 if (framebuffer->isComplete(context))
Shannon Woods53a94a82014-06-24 15:20:36 -04002153 {
Jamie Madill427064d2018-04-13 16:20:34 -04002154 GLint samples = framebuffer->getSamples(context);
Shannon Woods53a94a82014-06-24 15:20:36 -04002155 switch (pname)
2156 {
Jamie Madilla0016b72017-07-14 14:30:46 -04002157 case GL_SAMPLE_BUFFERS:
Jamie Madille98b1b52018-03-08 09:47:23 -05002158 if (samples != 0)
Jamie Madilla0016b72017-07-14 14:30:46 -04002159 {
2160 *params = 1;
2161 }
2162 else
2163 {
2164 *params = 0;
2165 }
2166 break;
2167 case GL_SAMPLES:
Jamie Madille98b1b52018-03-08 09:47:23 -05002168 *params = samples;
Jamie Madilla0016b72017-07-14 14:30:46 -04002169 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002170 }
2171 }
2172 else
2173 {
2174 *params = 0;
2175 }
2176 }
2177 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002178 case GL_VIEWPORT:
2179 params[0] = mViewport.x;
2180 params[1] = mViewport.y;
2181 params[2] = mViewport.width;
2182 params[3] = mViewport.height;
2183 break;
2184 case GL_SCISSOR_BOX:
2185 params[0] = mScissor.x;
2186 params[1] = mScissor.y;
2187 params[2] = mScissor.width;
2188 params[3] = mScissor.height;
2189 break;
2190 case GL_CULL_FACE_MODE:
2191 *params = ToGLenum(mRasterizer.cullMode);
2192 break;
2193 case GL_FRONT_FACE:
2194 *params = mRasterizer.frontFace;
2195 break;
2196 case GL_RED_BITS:
2197 case GL_GREEN_BITS:
2198 case GL_BLUE_BITS:
2199 case GL_ALPHA_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002200 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002201 Framebuffer *framebuffer = getDrawFramebuffer();
2202 const FramebufferAttachment *colorbuffer = framebuffer->getFirstColorbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002203
2204 if (colorbuffer)
2205 {
2206 switch (pname)
2207 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002208 case GL_RED_BITS:
2209 *params = colorbuffer->getRedSize();
2210 break;
2211 case GL_GREEN_BITS:
2212 *params = colorbuffer->getGreenSize();
2213 break;
2214 case GL_BLUE_BITS:
2215 *params = colorbuffer->getBlueSize();
2216 break;
2217 case GL_ALPHA_BITS:
2218 *params = colorbuffer->getAlphaSize();
2219 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002220 }
2221 }
2222 else
2223 {
2224 *params = 0;
2225 }
2226 }
2227 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002228 case GL_DEPTH_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002229 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002230 const Framebuffer *framebuffer = getDrawFramebuffer();
2231 const FramebufferAttachment *depthbuffer = framebuffer->getDepthbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002232
2233 if (depthbuffer)
2234 {
2235 *params = depthbuffer->getDepthSize();
2236 }
2237 else
2238 {
2239 *params = 0;
2240 }
2241 }
2242 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002243 case GL_STENCIL_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002244 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002245 const Framebuffer *framebuffer = getDrawFramebuffer();
2246 const FramebufferAttachment *stencilbuffer = framebuffer->getStencilbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002247
2248 if (stencilbuffer)
2249 {
2250 *params = stencilbuffer->getStencilSize();
2251 }
2252 else
2253 {
2254 *params = 0;
2255 }
2256 }
2257 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002258 case GL_TEXTURE_BINDING_2D:
2259 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2260 *params =
2261 getSamplerTextureId(static_cast<unsigned int>(mActiveSampler), TextureType::_2D);
2262 break;
2263 case GL_TEXTURE_BINDING_RECTANGLE_ANGLE:
2264 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2265 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2266 TextureType::Rectangle);
2267 break;
2268 case GL_TEXTURE_BINDING_CUBE_MAP:
2269 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2270 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2271 TextureType::CubeMap);
2272 break;
2273 case GL_TEXTURE_BINDING_3D:
2274 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2275 *params =
2276 getSamplerTextureId(static_cast<unsigned int>(mActiveSampler), TextureType::_3D);
2277 break;
2278 case GL_TEXTURE_BINDING_2D_ARRAY:
2279 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2280 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2281 TextureType::_2DArray);
2282 break;
2283 case GL_TEXTURE_BINDING_2D_MULTISAMPLE:
2284 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2285 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2286 TextureType::_2DMultisample);
2287 break;
2288 case GL_TEXTURE_BINDING_EXTERNAL_OES:
2289 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2290 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2291 TextureType::External);
2292 break;
2293 case GL_UNIFORM_BUFFER_BINDING:
2294 *params = mBoundBuffers[BufferBinding::Uniform].id();
2295 break;
2296 case GL_TRANSFORM_FEEDBACK_BINDING:
2297 *params = mTransformFeedback.id();
2298 break;
2299 case GL_TRANSFORM_FEEDBACK_BUFFER_BINDING:
2300 *params = mBoundBuffers[BufferBinding::TransformFeedback].id();
2301 break;
2302 case GL_COPY_READ_BUFFER_BINDING:
2303 *params = mBoundBuffers[BufferBinding::CopyRead].id();
2304 break;
2305 case GL_COPY_WRITE_BUFFER_BINDING:
2306 *params = mBoundBuffers[BufferBinding::CopyWrite].id();
2307 break;
2308 case GL_PIXEL_PACK_BUFFER_BINDING:
2309 *params = mBoundBuffers[BufferBinding::PixelPack].id();
2310 break;
2311 case GL_PIXEL_UNPACK_BUFFER_BINDING:
2312 *params = mBoundBuffers[BufferBinding::PixelUnpack].id();
2313 break;
2314 case GL_READ_BUFFER:
2315 *params = mReadFramebuffer->getReadBufferState();
2316 break;
2317 case GL_SAMPLER_BINDING:
2318 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2319 *params = getSamplerId(static_cast<GLuint>(mActiveSampler));
2320 break;
2321 case GL_DEBUG_LOGGED_MESSAGES:
2322 *params = static_cast<GLint>(mDebug.getMessageCount());
2323 break;
2324 case GL_DEBUG_NEXT_LOGGED_MESSAGE_LENGTH:
2325 *params = static_cast<GLint>(mDebug.getNextMessageLength());
2326 break;
2327 case GL_DEBUG_GROUP_STACK_DEPTH:
2328 *params = static_cast<GLint>(mDebug.getGroupStackDepth());
2329 break;
2330 case GL_MULTISAMPLE_EXT:
2331 *params = static_cast<GLint>(mMultiSampling);
2332 break;
2333 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
2334 *params = static_cast<GLint>(mSampleAlphaToOne);
2335 break;
2336 case GL_COVERAGE_MODULATION_CHROMIUM:
2337 *params = static_cast<GLint>(mCoverageModulation);
2338 break;
2339 case GL_ATOMIC_COUNTER_BUFFER_BINDING:
2340 *params = mBoundBuffers[BufferBinding::AtomicCounter].id();
2341 break;
2342 case GL_SHADER_STORAGE_BUFFER_BINDING:
2343 *params = mBoundBuffers[BufferBinding::ShaderStorage].id();
2344 break;
2345 case GL_DISPATCH_INDIRECT_BUFFER_BINDING:
2346 *params = mBoundBuffers[BufferBinding::DispatchIndirect].id();
2347 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -07002348 case GL_ALPHA_TEST_FUNC:
2349 *params = ToGLenum(mGLES1State.mAlphaTestFunc);
2350 break;
Lingfeng Yang96310cd2018-03-28 11:56:28 -07002351 case GL_CLIENT_ACTIVE_TEXTURE:
2352 *params = mGLES1State.mClientActiveTexture + GL_TEXTURE0;
2353 break;
Lingfeng Yangd2488ab2018-04-04 09:25:48 -07002354 case GL_MATRIX_MODE:
2355 *params = ToGLenum(mGLES1State.mMatrixMode);
2356 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002357 default:
2358 UNREACHABLE();
2359 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002360 }
Jamie Madille98b1b52018-03-08 09:47:23 -05002361
2362 return NoError();
Shannon Woods53a94a82014-06-24 15:20:36 -04002363}
2364
Lingfeng Yangabb09f12018-04-16 10:43:53 -07002365void State::getPointerv(const Context *context, GLenum pname, void **params) const
Geoff Lang70d0f492015-12-10 17:45:46 -05002366{
2367 switch (pname)
2368 {
2369 case GL_DEBUG_CALLBACK_FUNCTION:
2370 *params = reinterpret_cast<void *>(mDebug.getCallback());
2371 break;
2372 case GL_DEBUG_CALLBACK_USER_PARAM:
2373 *params = const_cast<void *>(mDebug.getUserParam());
2374 break;
Lingfeng Yangabb09f12018-04-16 10:43:53 -07002375 case GL_VERTEX_ARRAY_POINTER:
2376 case GL_NORMAL_ARRAY_POINTER:
2377 case GL_COLOR_ARRAY_POINTER:
2378 case GL_TEXTURE_COORD_ARRAY_POINTER:
2379 case GL_POINT_SIZE_ARRAY_POINTER_OES:
2380 QueryVertexAttribPointerv(getVertexArray()->getVertexAttribute(
2381 context->vertexArrayIndex(ParamToVertexArrayType(pname))),
2382 GL_VERTEX_ATTRIB_ARRAY_POINTER, params);
2383 return;
Geoff Lang70d0f492015-12-10 17:45:46 -05002384 default:
2385 UNREACHABLE();
2386 break;
2387 }
2388}
2389
Martin Radev66fb8202016-07-28 11:45:20 +03002390void State::getIntegeri_v(GLenum target, GLuint index, GLint *data)
Shannon Woods53a94a82014-06-24 15:20:36 -04002391{
2392 switch (target)
2393 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002394 case GL_TRANSFORM_FEEDBACK_BUFFER_BINDING:
2395 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2396 *data = mTransformFeedback->getIndexedBuffer(index).id();
2397 break;
2398 case GL_UNIFORM_BUFFER_BINDING:
2399 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2400 *data = mUniformBuffers[index].id();
2401 break;
2402 case GL_ATOMIC_COUNTER_BUFFER_BINDING:
2403 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2404 *data = mAtomicCounterBuffers[index].id();
2405 break;
2406 case GL_SHADER_STORAGE_BUFFER_BINDING:
2407 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2408 *data = mShaderStorageBuffers[index].id();
2409 break;
2410 case GL_VERTEX_BINDING_BUFFER:
2411 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2412 *data = mVertexArray->getVertexBinding(index).getBuffer().id();
2413 break;
2414 case GL_VERTEX_BINDING_DIVISOR:
2415 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2416 *data = mVertexArray->getVertexBinding(index).getDivisor();
2417 break;
2418 case GL_VERTEX_BINDING_OFFSET:
2419 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2420 *data = static_cast<GLuint>(mVertexArray->getVertexBinding(index).getOffset());
2421 break;
2422 case GL_VERTEX_BINDING_STRIDE:
2423 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2424 *data = mVertexArray->getVertexBinding(index).getStride();
2425 break;
2426 case GL_SAMPLE_MASK_VALUE:
2427 ASSERT(static_cast<size_t>(index) < mSampleMaskValues.size());
2428 *data = mSampleMaskValues[index];
2429 break;
2430 case GL_IMAGE_BINDING_NAME:
2431 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2432 *data = mImageUnits[index].texture.id();
2433 break;
2434 case GL_IMAGE_BINDING_LEVEL:
2435 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2436 *data = mImageUnits[index].level;
2437 break;
2438 case GL_IMAGE_BINDING_LAYER:
2439 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2440 *data = mImageUnits[index].layer;
2441 break;
2442 case GL_IMAGE_BINDING_ACCESS:
2443 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2444 *data = mImageUnits[index].access;
2445 break;
2446 case GL_IMAGE_BINDING_FORMAT:
2447 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2448 *data = mImageUnits[index].format;
2449 break;
2450 default:
2451 UNREACHABLE();
2452 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002453 }
Shannon Woods53a94a82014-06-24 15:20:36 -04002454}
2455
Martin Radev66fb8202016-07-28 11:45:20 +03002456void State::getInteger64i_v(GLenum target, GLuint index, GLint64 *data)
Shannon Woods53a94a82014-06-24 15:20:36 -04002457{
2458 switch (target)
2459 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002460 case GL_TRANSFORM_FEEDBACK_BUFFER_START:
2461 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2462 *data = mTransformFeedback->getIndexedBuffer(index).getOffset();
2463 break;
2464 case GL_TRANSFORM_FEEDBACK_BUFFER_SIZE:
2465 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2466 *data = mTransformFeedback->getIndexedBuffer(index).getSize();
2467 break;
2468 case GL_UNIFORM_BUFFER_START:
2469 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2470 *data = mUniformBuffers[index].getOffset();
2471 break;
2472 case GL_UNIFORM_BUFFER_SIZE:
2473 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2474 *data = mUniformBuffers[index].getSize();
2475 break;
2476 case GL_ATOMIC_COUNTER_BUFFER_START:
2477 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2478 *data = mAtomicCounterBuffers[index].getOffset();
2479 break;
2480 case GL_ATOMIC_COUNTER_BUFFER_SIZE:
2481 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2482 *data = mAtomicCounterBuffers[index].getSize();
2483 break;
2484 case GL_SHADER_STORAGE_BUFFER_START:
2485 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2486 *data = mShaderStorageBuffers[index].getOffset();
2487 break;
2488 case GL_SHADER_STORAGE_BUFFER_SIZE:
2489 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2490 *data = mShaderStorageBuffers[index].getSize();
2491 break;
2492 default:
2493 UNREACHABLE();
2494 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002495 }
Martin Radev66fb8202016-07-28 11:45:20 +03002496}
Shannon Woods53a94a82014-06-24 15:20:36 -04002497
Martin Radev66fb8202016-07-28 11:45:20 +03002498void State::getBooleani_v(GLenum target, GLuint index, GLboolean *data)
2499{
Xinghua Cao9c8e1a32017-12-06 17:59:58 +08002500 switch (target)
2501 {
2502 case GL_IMAGE_BINDING_LAYERED:
2503 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2504 *data = mImageUnits[index].layered;
2505 break;
2506 default:
2507 UNREACHABLE();
2508 break;
2509 }
Shannon Woods53a94a82014-06-24 15:20:36 -04002510}
2511
Corentin Wallez336129f2017-10-17 15:55:40 -04002512bool State::hasMappedBuffer(BufferBinding target) const
Jamie Madilld9ba4f72014-08-04 10:47:59 -04002513{
Corentin Wallez336129f2017-10-17 15:55:40 -04002514 if (target == BufferBinding::Array)
Jamie Madilld9ba4f72014-08-04 10:47:59 -04002515 {
Jiawei-Shao2597fb62016-12-09 16:38:02 +08002516 const VertexArray *vao = getVertexArray();
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002517 const auto &vertexAttribs = vao->getVertexAttributes();
Jiawei-Shao2597fb62016-12-09 16:38:02 +08002518 const auto &vertexBindings = vao->getVertexBindings();
Jamie Madilld078c682018-01-02 11:50:24 -05002519 for (size_t attribIndex : vao->getEnabledAttributesMask())
Jamie Madilld9ba4f72014-08-04 10:47:59 -04002520 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002521 const VertexAttribute &vertexAttrib = vertexAttribs[attribIndex];
Martin Radevdd5f27e2017-06-07 10:17:09 +03002522 auto *boundBuffer = vertexBindings[vertexAttrib.bindingIndex].getBuffer().get();
Jamie Madilld9ba4f72014-08-04 10:47:59 -04002523 if (vertexAttrib.enabled && boundBuffer && boundBuffer->isMapped())
2524 {
2525 return true;
2526 }
2527 }
2528
2529 return false;
2530 }
2531 else
2532 {
2533 Buffer *buffer = getTargetBuffer(target);
2534 return (buffer && buffer->isMapped());
2535 }
2536}
2537
Jamie Madillbc918e72018-03-08 09:47:21 -05002538Error State::syncDirtyObjects(const Context *context)
Jamie Madillc9d442d2016-01-20 11:17:24 -05002539{
2540 if (!mDirtyObjects.any())
Jamie Madillbc918e72018-03-08 09:47:21 -05002541 return NoError();
Jamie Madillc9d442d2016-01-20 11:17:24 -05002542
Jamie Madillbc918e72018-03-08 09:47:21 -05002543 return syncDirtyObjects(context, mDirtyObjects);
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002544}
2545
Jamie Madillbc918e72018-03-08 09:47:21 -05002546Error State::syncDirtyObjects(const Context *context, const DirtyObjects &bitset)
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002547{
Jiajia Qin5ae6ee42018-03-06 17:39:42 +08002548 const DirtyObjects &dirtyObjects = mDirtyObjects & bitset;
2549 for (auto dirtyObject : dirtyObjects)
Jamie Madillc9d442d2016-01-20 11:17:24 -05002550 {
2551 switch (dirtyObject)
2552 {
2553 case DIRTY_OBJECT_READ_FRAMEBUFFER:
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002554 ASSERT(mReadFramebuffer);
Jamie Madill19fa1c62018-03-08 09:47:21 -05002555 ANGLE_TRY(mReadFramebuffer->syncState(context));
Jamie Madillc9d442d2016-01-20 11:17:24 -05002556 break;
2557 case DIRTY_OBJECT_DRAW_FRAMEBUFFER:
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002558 ASSERT(mDrawFramebuffer);
Jamie Madill19fa1c62018-03-08 09:47:21 -05002559 ANGLE_TRY(mDrawFramebuffer->syncState(context));
Jamie Madillc9d442d2016-01-20 11:17:24 -05002560 break;
2561 case DIRTY_OBJECT_VERTEX_ARRAY:
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002562 ASSERT(mVertexArray);
Frank Henigman0af5b862018-03-27 20:19:33 -04002563 ANGLE_TRY(mVertexArray->syncState(context));
Jamie Madillc9d442d2016-01-20 11:17:24 -05002564 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002565 case DIRTY_OBJECT_PROGRAM_TEXTURES:
Luc Ferron4bba74f2018-04-19 14:40:45 -04002566 ANGLE_TRY(syncProgramTextures(context));
Jamie Madill81c2e252017-09-09 23:32:46 -04002567 break;
2568
Jamie Madillc9d442d2016-01-20 11:17:24 -05002569 default:
2570 UNREACHABLE();
2571 break;
2572 }
2573 }
2574
Jiajia Qin5ae6ee42018-03-06 17:39:42 +08002575 mDirtyObjects &= ~dirtyObjects;
Jamie Madillbc918e72018-03-08 09:47:21 -05002576 return NoError();
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002577}
2578
Luc Ferron4bba74f2018-04-19 14:40:45 -04002579Error State::syncProgramTextures(const Context *context)
Jamie Madill81c2e252017-09-09 23:32:46 -04002580{
Jamie Madill81c2e252017-09-09 23:32:46 -04002581 // TODO(jmadill): Fine-grained updates.
2582 if (!mProgram)
2583 {
Luc Ferron4bba74f2018-04-19 14:40:45 -04002584 return NoError();
Jamie Madill81c2e252017-09-09 23:32:46 -04002585 }
2586
2587 ASSERT(mDirtyObjects[DIRTY_OBJECT_PROGRAM_TEXTURES]);
2588 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
2589
Jamie Madill0f80ed82017-09-19 00:24:56 -04002590 ActiveTextureMask newActiveTextures;
2591
Geoff Lange51ba632017-11-21 11:45:25 -05002592 // Initialize to the 'Initialized' state and set to 'MayNeedInit' if any texture is not
2593 // initialized.
2594 mCachedTexturesInitState = InitState::Initialized;
2595
Jamie Madill81c2e252017-09-09 23:32:46 -04002596 for (const SamplerBinding &samplerBinding : mProgram->getSamplerBindings())
2597 {
2598 if (samplerBinding.unreferenced)
2599 continue;
2600
Corentin Wallezf0e89be2017-11-08 14:00:32 -08002601 TextureType textureType = samplerBinding.textureType;
Jamie Madill81c2e252017-09-09 23:32:46 -04002602 for (GLuint textureUnitIndex : samplerBinding.boundTextureUnits)
2603 {
2604 Texture *texture = getSamplerTexture(textureUnitIndex, textureType);
Jamie Madill06ef36b2017-09-09 23:32:46 -04002605 Sampler *sampler = getSampler(textureUnitIndex);
Jamie Madill0f80ed82017-09-19 00:24:56 -04002606 ASSERT(static_cast<size_t>(textureUnitIndex) < mCompleteTextureCache.size());
2607 ASSERT(static_cast<size_t>(textureUnitIndex) < newActiveTextures.size());
Jamie Madill81c2e252017-09-09 23:32:46 -04002608
Jamie Madill42975642017-10-12 12:31:51 -04002609 ASSERT(texture);
Jamie Madill81c2e252017-09-09 23:32:46 -04002610
Jamie Madill42975642017-10-12 12:31:51 -04002611 // Mark the texture binding bit as dirty if the texture completeness changes.
2612 // TODO(jmadill): Use specific dirty bit for completeness change.
2613 if (texture->isSamplerComplete(context, sampler) &&
2614 !mDrawFramebuffer->hasTextureAttachment(texture))
2615 {
Luc Ferron4bba74f2018-04-19 14:40:45 -04002616 ANGLE_TRY(texture->syncState(context));
Jamie Madill42975642017-10-12 12:31:51 -04002617 mCompleteTextureCache[textureUnitIndex] = texture;
Jamie Madill81c2e252017-09-09 23:32:46 -04002618 }
Jamie Madill42975642017-10-12 12:31:51 -04002619 else
2620 {
2621 mCompleteTextureCache[textureUnitIndex] = nullptr;
2622 }
2623
2624 // Bind the texture unconditionally, to recieve completeness change notifications.
Jamie Madill888081d2018-02-27 00:24:46 -05002625 mCompleteTextureBindings[textureUnitIndex].bind(texture->getSubject());
Jamie Madilla59fc192017-11-02 12:57:58 -04002626 mActiveTexturesMask.set(textureUnitIndex);
Jamie Madill42975642017-10-12 12:31:51 -04002627 newActiveTextures.set(textureUnitIndex);
Jamie Madill81c2e252017-09-09 23:32:46 -04002628
Jamie Madill06ef36b2017-09-09 23:32:46 -04002629 if (sampler != nullptr)
2630 {
2631 sampler->syncState(context);
2632 }
Geoff Lange51ba632017-11-21 11:45:25 -05002633
2634 if (texture->initState() == InitState::MayNeedInit)
2635 {
2636 mCachedTexturesInitState = InitState::MayNeedInit;
2637 }
Jamie Madill81c2e252017-09-09 23:32:46 -04002638 }
2639 }
Jamie Madill0f80ed82017-09-19 00:24:56 -04002640
2641 // Unset now missing textures.
Jamie Madilla59fc192017-11-02 12:57:58 -04002642 ActiveTextureMask negativeMask = mActiveTexturesMask & ~newActiveTextures;
Jamie Madill0f80ed82017-09-19 00:24:56 -04002643 if (negativeMask.any())
2644 {
2645 for (auto textureIndex : negativeMask)
2646 {
2647 mCompleteTextureBindings[textureIndex].reset();
2648 mCompleteTextureCache[textureIndex] = nullptr;
Jamie Madilla59fc192017-11-02 12:57:58 -04002649 mActiveTexturesMask.reset(textureIndex);
Jamie Madill0f80ed82017-09-19 00:24:56 -04002650 }
2651 }
Luc Ferron4bba74f2018-04-19 14:40:45 -04002652
2653 return NoError();
Jamie Madill81c2e252017-09-09 23:32:46 -04002654}
2655
Jamie Madillbc918e72018-03-08 09:47:21 -05002656Error State::syncDirtyObject(const Context *context, GLenum target)
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002657{
2658 DirtyObjects localSet;
2659
2660 switch (target)
2661 {
2662 case GL_READ_FRAMEBUFFER:
2663 localSet.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2664 break;
2665 case GL_DRAW_FRAMEBUFFER:
2666 localSet.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2667 break;
2668 case GL_FRAMEBUFFER:
2669 localSet.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2670 localSet.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2671 break;
2672 case GL_VERTEX_ARRAY:
2673 localSet.set(DIRTY_OBJECT_VERTEX_ARRAY);
2674 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002675 case GL_TEXTURE:
2676 case GL_SAMPLER:
2677 case GL_PROGRAM:
2678 localSet.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
2679 break;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002680 }
2681
Jamie Madillbc918e72018-03-08 09:47:21 -05002682 return syncDirtyObjects(context, localSet);
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002683}
2684
2685void State::setObjectDirty(GLenum target)
2686{
2687 switch (target)
2688 {
2689 case GL_READ_FRAMEBUFFER:
2690 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2691 break;
2692 case GL_DRAW_FRAMEBUFFER:
2693 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2694 break;
2695 case GL_FRAMEBUFFER:
2696 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2697 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2698 break;
2699 case GL_VERTEX_ARRAY:
2700 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
2701 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002702 case GL_TEXTURE:
2703 case GL_SAMPLER:
Jamie Madill81c2e252017-09-09 23:32:46 -04002704 case GL_PROGRAM:
2705 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
2706 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
2707 break;
Jamie Madilla779b612017-07-24 11:46:05 -04002708 }
2709}
2710
Jamie Madill888081d2018-02-27 00:24:46 -05002711void State::setFramebufferDirty(const Framebuffer *framebuffer) const
2712{
2713 if (framebuffer == mReadFramebuffer)
2714 {
2715 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2716 }
2717 if (framebuffer == mDrawFramebuffer)
2718 {
2719 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2720 }
2721}
2722
Jamie Madill09463932018-04-04 05:26:59 -04002723void State::setVertexArrayDirty(const VertexArray *vertexArray) const
2724{
2725 if (vertexArray == mVertexArray)
2726 {
2727 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
2728 }
2729}
2730
Jamie Madilla779b612017-07-24 11:46:05 -04002731void State::onProgramExecutableChange(Program *program)
2732{
2733 // OpenGL Spec:
2734 // "If LinkProgram or ProgramBinary successfully re-links a program object
2735 // that was already in use as a result of a previous call to UseProgram, then the
2736 // generated executable code will be installed as part of the current rendering state."
2737 if (program->isLinked() && mProgram == program)
2738 {
2739 mDirtyBits.set(DIRTY_BIT_PROGRAM_EXECUTABLE);
Jamie Madill81c2e252017-09-09 23:32:46 -04002740 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002741 }
Shannon Woods53a94a82014-06-24 15:20:36 -04002742}
Jamie Madillc9d442d2016-01-20 11:17:24 -05002743
Xinghua Cao65ec0b22017-03-28 16:10:52 +08002744void State::setImageUnit(const Context *context,
2745 GLuint unit,
2746 Texture *texture,
2747 GLint level,
2748 GLboolean layered,
2749 GLint layer,
2750 GLenum access,
2751 GLenum format)
2752{
2753 mImageUnits[unit].texture.set(context, texture);
2754 mImageUnits[unit].level = level;
2755 mImageUnits[unit].layered = layered;
2756 mImageUnits[unit].layer = layer;
2757 mImageUnits[unit].access = access;
2758 mImageUnits[unit].format = format;
2759}
2760
2761const ImageUnit &State::getImageUnit(GLuint unit) const
2762{
2763 return mImageUnits[unit];
2764}
2765
Jamie Madill81c2e252017-09-09 23:32:46 -04002766// Handle a dirty texture event.
Jamie Madilld4442552018-02-27 22:03:47 -05002767void State::onSubjectStateChange(const Context *context,
2768 angle::SubjectIndex index,
2769 angle::SubjectMessage message)
Jamie Madill81c2e252017-09-09 23:32:46 -04002770{
2771 // Conservatively assume all textures are dirty.
2772 // TODO(jmadill): More fine-grained update.
2773 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Geoff Lange51ba632017-11-21 11:45:25 -05002774
Jamie Madilld4442552018-02-27 22:03:47 -05002775 if (!mCompleteTextureCache[index] ||
2776 mCompleteTextureCache[index]->initState() == InitState::MayNeedInit)
Geoff Lange51ba632017-11-21 11:45:25 -05002777 {
2778 mCachedTexturesInitState = InitState::MayNeedInit;
2779 }
Jamie Madill81c2e252017-09-09 23:32:46 -04002780}
2781
Jamie Madill05b35b22017-10-03 09:01:44 -04002782Error State::clearUnclearedActiveTextures(const Context *context)
2783{
Jamie Madilla59fc192017-11-02 12:57:58 -04002784 ASSERT(mRobustResourceInit);
Jamie Madill05b35b22017-10-03 09:01:44 -04002785
Geoff Lange51ba632017-11-21 11:45:25 -05002786 if (mCachedTexturesInitState == InitState::Initialized)
2787 {
2788 return NoError();
2789 }
2790
Geoff Langd4fff502017-09-22 11:28:28 -04002791 ASSERT(!mDirtyObjects.any());
2792
Jamie Madilla59fc192017-11-02 12:57:58 -04002793 for (auto textureIndex : mActiveTexturesMask)
Jamie Madill05b35b22017-10-03 09:01:44 -04002794 {
Jamie Madilla59fc192017-11-02 12:57:58 -04002795 Texture *texture = mCompleteTextureCache[textureIndex];
Jamie Madill05b35b22017-10-03 09:01:44 -04002796 if (texture)
2797 {
2798 ANGLE_TRY(texture->ensureInitialized(context));
2799 }
2800 }
Jamie Madilla59fc192017-11-02 12:57:58 -04002801
Geoff Lange51ba632017-11-21 11:45:25 -05002802 mCachedTexturesInitState = InitState::Initialized;
2803
Jamie Madill05b35b22017-10-03 09:01:44 -04002804 return NoError();
2805}
2806
Jamie Madillc67323a2017-11-02 23:11:41 -04002807AttributesMask State::getAndResetDirtyCurrentValues() const
2808{
2809 AttributesMask retVal = mDirtyCurrentValues;
2810 mDirtyCurrentValues.reset();
2811 return retVal;
2812}
2813
James Darpiniane8a93c62018-01-04 18:02:24 -08002814bool State::isCurrentTransformFeedback(const TransformFeedback *tf) const
2815{
2816 return tf == mTransformFeedback.get();
2817}
2818bool State::isCurrentVertexArray(const VertexArray *va) const
2819{
2820 return va == mVertexArray;
2821}
2822
Jamie Madillc9d442d2016-01-20 11:17:24 -05002823} // namespace gl