blob: 0c29a3e8045d883f5b105e9cd5fc55101f507ad8 [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"
Jamie Madillf668a4b2018-09-23 17:01:20 -040028#include "libANGLE/renderer/TextureImpl.h"
Shannon Woods53a94a82014-06-24 15:20:36 -040029
Corentin Wallezad3ae902018-03-09 13:40:42 -050030namespace gl
31{
32
Olli Etuahobbf1c102016-06-28 13:31:33 +030033namespace
34{
35
Corentin Wallezad3ae902018-03-09 13:40:42 -050036bool GetAlternativeQueryType(QueryType type, QueryType *alternativeType)
Olli Etuahobbf1c102016-06-28 13:31:33 +030037{
Corentin Wallezad3ae902018-03-09 13:40:42 -050038 switch (type)
39 {
40 case QueryType::AnySamples:
41 *alternativeType = QueryType::AnySamplesConservative;
42 return true;
43 case QueryType::AnySamplesConservative:
44 *alternativeType = QueryType::AnySamples;
45 return true;
46 default:
47 return false;
48 }
Olli Etuahobbf1c102016-06-28 13:31:33 +030049}
50
51} // anonymous namepace
52
Jamie Madillbf5177d2018-08-21 12:58:20 -040053template <typename BindingT, typename... ArgsT>
54void UpdateNonTFBufferBinding(const Context *context, BindingT *binding, ArgsT... args)
James Darpiniane8a93c62018-01-04 18:02:24 -080055{
56 if (binding->get())
Jamie Madillbf5177d2018-08-21 12:58:20 -040057 (*binding)->onNonTFBindingChanged(context, -1);
58 binding->set(context, args...);
James Darpiniane8a93c62018-01-04 18:02:24 -080059 if (binding->get())
Jamie Madillbf5177d2018-08-21 12:58:20 -040060 (*binding)->onNonTFBindingChanged(context, 1);
61}
62
63template <typename BindingT, typename... ArgsT>
64void UpdateTFBufferBinding(const Context *context, BindingT *binding, bool indexed, ArgsT... args)
65{
66 if (binding->get())
67 (*binding)->onTFBindingChanged(context, false, indexed);
68 binding->set(context, args...);
69 if (binding->get())
70 (*binding)->onTFBindingChanged(context, true, indexed);
James Darpiniane8a93c62018-01-04 18:02:24 -080071}
72
73void UpdateBufferBinding(const Context *context,
Jamie Madillbf5177d2018-08-21 12:58:20 -040074 BindingPointer<Buffer> *binding,
James Darpiniane8a93c62018-01-04 18:02:24 -080075 Buffer *buffer,
Jamie Madillbf5177d2018-08-21 12:58:20 -040076 BufferBinding target)
James Darpiniane8a93c62018-01-04 18:02:24 -080077{
Jamie Madillbf5177d2018-08-21 12:58:20 -040078 if (target == BufferBinding::TransformFeedback)
79 {
80 UpdateTFBufferBinding(context, binding, false, buffer);
81 }
82 else
83 {
84 UpdateNonTFBufferBinding(context, binding, buffer);
85 }
86}
87
88void UpdateIndexedBufferBinding(const Context *context,
89 OffsetBindingPointer<Buffer> *binding,
90 Buffer *buffer,
91 BufferBinding target,
92 GLintptr offset,
93 GLsizeiptr size)
94{
95 if (target == BufferBinding::TransformFeedback)
96 {
97 UpdateTFBufferBinding(context, binding, true, buffer, offset, size);
98 }
99 else
100 {
101 UpdateNonTFBufferBinding(context, binding, buffer, offset, size);
102 }
James Darpiniane8a93c62018-01-04 18:02:24 -0800103}
104
Geoff Lang4fb8a8b2018-06-01 16:47:57 -0400105State::State(bool debug,
106 bool bindGeneratesResource,
107 bool clientArraysEnabled,
108 bool robustResourceInit,
109 bool programBinaryCacheEnabled)
Jamie Madille79b1e12015-11-04 16:36:37 -0500110 : mMaxDrawBuffers(0),
111 mMaxCombinedTextureImageUnits(0),
112 mDepthClearValue(0),
113 mStencilClearValue(0),
114 mScissorTest(false),
115 mSampleCoverage(false),
116 mSampleCoverageValue(0),
117 mSampleCoverageInvert(false),
Jiawei Shaodb342272017-09-27 10:21:45 +0800118 mSampleMask(false),
119 mMaxSampleMaskWords(0),
Jamie Madille79b1e12015-11-04 16:36:37 -0500120 mStencilRef(0),
121 mStencilBackRef(0),
122 mLineWidth(0),
123 mGenerateMipmapHint(GL_NONE),
124 mFragmentShaderDerivativeHint(GL_NONE),
Geoff Lang4fb8a8b2018-06-01 16:47:57 -0400125 mBindGeneratesResource(bindGeneratesResource),
126 mClientArraysEnabled(clientArraysEnabled),
Jamie Madille79b1e12015-11-04 16:36:37 -0500127 mNearZ(0),
128 mFarZ(0),
129 mReadFramebuffer(nullptr),
130 mDrawFramebuffer(nullptr),
131 mProgram(nullptr),
132 mVertexArray(nullptr),
133 mActiveSampler(0),
Jamie Madill4787d702018-08-08 15:49:26 -0400134 mActiveTexturesCache{},
135 mCachedTexturesInitState(InitState::MayNeedInit),
Qin Jiajia47f6dd02018-08-10 13:36:32 +0800136 mCachedImageTexturesInitState(InitState::MayNeedInit),
Sami Väisänen74c23472016-05-09 17:30:30 +0300137 mPrimitiveRestart(false),
Geoff Lang4fb8a8b2018-06-01 16:47:57 -0400138 mDebug(debug),
Sami Väisänen74c23472016-05-09 17:30:30 +0300139 mMultiSampling(false),
Geoff Lang1d2c41d2016-10-19 16:14:46 -0700140 mSampleAlphaToOne(false),
Jamie Madille08a1d32017-03-07 17:24:06 -0500141 mFramebufferSRGB(true),
Geoff Lang4fb8a8b2018-06-01 16:47:57 -0400142 mRobustResourceInit(robustResourceInit),
jchen1082af6202018-06-22 10:59:52 +0800143 mProgramBinaryCacheEnabled(programBinaryCacheEnabled),
144 mMaxShaderCompilerThreads(std::numeric_limits<GLuint>::max())
Shannon Woods53a94a82014-06-24 15:20:36 -0400145{
Geoff Lang76b10c92014-09-05 16:28:14 -0400146}
147
Lingfeng Yang13b708f2018-03-21 12:14:10 -0700148State::~State()
149{
150}
Geoff Lang76b10c92014-09-05 16:28:14 -0400151
Jamie Madill6c43a012018-08-08 15:49:27 -0400152void State::initialize(Context *context)
Geoff Lang76b10c92014-09-05 16:28:14 -0400153{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700154 const Caps &caps = context->getCaps();
155 const Extensions &extensions = context->getExtensions();
Geoff Lang4751aab2017-10-30 15:14:52 -0400156 const Extensions &nativeExtensions = context->getImplementation()->getNativeExtensions();
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700157 const Version &clientVersion = context->getClientVersion();
Jamie Madill4928b7c2017-06-20 12:57:39 -0400158
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700159 mMaxDrawBuffers = caps.maxDrawBuffers;
Shannon Woods2df6a602014-09-26 16:12:07 -0400160 mMaxCombinedTextureImageUnits = caps.maxCombinedTextureImageUnits;
Shannon Woods53a94a82014-06-24 15:20:36 -0400161
Jamie Madillf75ab352015-03-16 10:46:52 -0400162 setColorClearValue(0.0f, 0.0f, 0.0f, 0.0f);
Shannon Woods53a94a82014-06-24 15:20:36 -0400163
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700164 mDepthClearValue = 1.0f;
Shannon Woods53a94a82014-06-24 15:20:36 -0400165 mStencilClearValue = 0;
166
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700167 mScissorTest = false;
168 mScissor.x = 0;
169 mScissor.y = 0;
170 mScissor.width = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400171 mScissor.height = 0;
172
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700173 mBlendColor.red = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400174 mBlendColor.green = 0;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700175 mBlendColor.blue = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400176 mBlendColor.alpha = 0;
177
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700178 mStencilRef = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400179 mStencilBackRef = 0;
180
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700181 mSampleCoverage = false;
182 mSampleCoverageValue = 1.0f;
Shannon Woods53a94a82014-06-24 15:20:36 -0400183 mSampleCoverageInvert = false;
Jiawei Shaodb342272017-09-27 10:21:45 +0800184
185 mMaxSampleMaskWords = caps.maxSampleMaskWords;
186 mSampleMask = false;
187 mSampleMaskValues.fill(~GLbitfield(0));
188
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700189 mGenerateMipmapHint = GL_DONT_CARE;
Shannon Woods53a94a82014-06-24 15:20:36 -0400190 mFragmentShaderDerivativeHint = GL_DONT_CARE;
191
192 mLineWidth = 1.0f;
193
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700194 mViewport.x = 0;
195 mViewport.y = 0;
196 mViewport.width = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400197 mViewport.height = 0;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700198 mNearZ = 0.0f;
199 mFarZ = 1.0f;
Shannon Woods53a94a82014-06-24 15:20:36 -0400200
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700201 mBlend.colorMaskRed = true;
Shannon Woods53a94a82014-06-24 15:20:36 -0400202 mBlend.colorMaskGreen = true;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700203 mBlend.colorMaskBlue = true;
Shannon Woods53a94a82014-06-24 15:20:36 -0400204 mBlend.colorMaskAlpha = true;
205
Geoff Lang76b10c92014-09-05 16:28:14 -0400206 mActiveSampler = 0;
207
Shannon Woods23e05002014-09-22 19:07:27 -0400208 mVertexAttribCurrentValues.resize(caps.maxVertexAttributes);
Shannon Woods53a94a82014-06-24 15:20:36 -0400209
Brandon Jonesc405ae72017-12-06 14:15:03 -0800210 // Set all indexes in state attributes type mask to float (default)
211 for (int i = 0; i < MAX_VERTEX_ATTRIBS; i++)
212 {
213 mCurrentValuesTypeMask.setIndex(GL_FLOAT, i);
214 }
215
Geoff Lang4dc3af02016-11-18 14:09:27 -0500216 mUniformBuffers.resize(caps.maxUniformBufferBindings);
Shannon Woodsf3acaf92014-09-23 18:07:11 -0400217
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800218 mSamplerTextures[TextureType::_2D].resize(caps.maxCombinedTextureImageUnits);
219 mSamplerTextures[TextureType::CubeMap].resize(caps.maxCombinedTextureImageUnits);
Geoff Langeb66a6e2016-10-31 13:06:12 -0400220 if (clientVersion >= Version(3, 0))
Shannon Woods53a94a82014-06-24 15:20:36 -0400221 {
Geoff Lang76b10c92014-09-05 16:28:14 -0400222 // TODO: These could also be enabled via extension
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800223 mSamplerTextures[TextureType::_2DArray].resize(caps.maxCombinedTextureImageUnits);
224 mSamplerTextures[TextureType::_3D].resize(caps.maxCombinedTextureImageUnits);
Shannon Woods53a94a82014-06-24 15:20:36 -0400225 }
Geoff Lang3b573612016-10-31 14:08:10 -0400226 if (clientVersion >= Version(3, 1))
227 {
Olli Etuahod310a432018-08-24 15:40:23 +0300228 // TODO(http://anglebug.com/2775): These could also be enabled via extension
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800229 mSamplerTextures[TextureType::_2DMultisample].resize(caps.maxCombinedTextureImageUnits);
Olli Etuahod310a432018-08-24 15:40:23 +0300230 mSamplerTextures[TextureType::_2DMultisampleArray].resize(
231 caps.maxCombinedTextureImageUnits);
Jiajia Qin6eafb042016-12-27 17:04:07 +0800232
233 mAtomicCounterBuffers.resize(caps.maxAtomicCounterBufferBindings);
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800234 mShaderStorageBuffers.resize(caps.maxShaderStorageBufferBindings);
Xinghua Cao65ec0b22017-03-28 16:10:52 +0800235 mImageUnits.resize(caps.maxImageUnits);
Geoff Lang3b573612016-10-31 14:08:10 -0400236 }
Geoff Lang4751aab2017-10-30 15:14:52 -0400237 if (nativeExtensions.textureRectangle)
Corentin Wallez13c0dd42017-07-04 18:27:01 -0400238 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800239 mSamplerTextures[TextureType::Rectangle].resize(caps.maxCombinedTextureImageUnits);
Corentin Wallez13c0dd42017-07-04 18:27:01 -0400240 }
Geoff Lang4751aab2017-10-30 15:14:52 -0400241 if (nativeExtensions.eglImageExternal || nativeExtensions.eglStreamConsumerExternal)
Ian Ewellbda75592016-04-18 17:25:54 -0400242 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800243 mSamplerTextures[TextureType::External].resize(caps.maxCombinedTextureImageUnits);
Ian Ewellbda75592016-04-18 17:25:54 -0400244 }
Jamie Madill81c2e252017-09-09 23:32:46 -0400245 mCompleteTextureBindings.reserve(caps.maxCombinedTextureImageUnits);
Geoff Lange51ba632017-11-21 11:45:25 -0500246 mCachedTexturesInitState = InitState::MayNeedInit;
Qin Jiajia47f6dd02018-08-10 13:36:32 +0800247 mCachedImageTexturesInitState = InitState::MayNeedInit;
Jamie Madill81c2e252017-09-09 23:32:46 -0400248 for (uint32_t textureIndex = 0; textureIndex < caps.maxCombinedTextureImageUnits;
249 ++textureIndex)
250 {
Jamie Madill6c43a012018-08-08 15:49:27 -0400251 mCompleteTextureBindings.emplace_back(context, textureIndex);
Jamie Madill81c2e252017-09-09 23:32:46 -0400252 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400253
Geoff Lang76b10c92014-09-05 16:28:14 -0400254 mSamplers.resize(caps.maxCombinedTextureImageUnits);
Shannon Woods53a94a82014-06-24 15:20:36 -0400255
Corentin Wallezad3ae902018-03-09 13:40:42 -0500256 for (QueryType type : angle::AllEnums<QueryType>())
257 {
258 mActiveQueries[type].set(context, nullptr);
259 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400260
Ian Ewell3ffd78b2016-01-22 16:09:42 -0500261 mProgram = nullptr;
Shannon Woods53a94a82014-06-24 15:20:36 -0400262
Ian Ewell3ffd78b2016-01-22 16:09:42 -0500263 mReadFramebuffer = nullptr;
264 mDrawFramebuffer = nullptr;
Jamie Madillb4b53c52015-02-03 15:22:48 -0500265
266 mPrimitiveRestart = false;
Geoff Lang70d0f492015-12-10 17:45:46 -0500267
Geoff Lang70d0f492015-12-10 17:45:46 -0500268 mDebug.setMaxLoggedMessages(extensions.maxDebugLoggedMessages);
Sami Väisänen74c23472016-05-09 17:30:30 +0300269
Geoff Lang488130e2017-09-27 13:53:11 -0400270 mMultiSampling = true;
271 mSampleAlphaToOne = false;
Sami Väisänena797e062016-05-12 15:23:40 +0300272
273 mCoverageModulation = GL_NONE;
Sami Väisänene45e53b2016-05-25 10:36:04 +0300274
275 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixProj);
276 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixMV);
277 mPathStencilFunc = GL_ALWAYS;
278 mPathStencilRef = 0;
279 mPathStencilMask = std::numeric_limits<GLuint>::max();
Jamie Madille08a1d32017-03-07 17:24:06 -0500280
Lingfeng Yangdbb9c532018-02-25 19:58:24 -0800281 // GLES1 emulation: Initialize state for GLES1 if version
282 // applies
283 if (clientVersion < Version(2, 0))
284 {
Lingfeng Yange547aac2018-04-05 09:39:20 -0700285 mGLES1State.initialize(context, this);
Lingfeng Yangdbb9c532018-02-25 19:58:24 -0800286 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400287}
288
Jamie Madill6c1f6712017-02-14 19:08:04 -0500289void State::reset(const Context *context)
Shannon Woods53a94a82014-06-24 15:20:36 -0400290{
Jamie Madill8693bdb2017-09-02 15:32:14 -0400291 for (auto &bindingVec : mSamplerTextures)
Shannon Woods53a94a82014-06-24 15:20:36 -0400292 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800293 for (size_t textureIdx = 0; textureIdx < bindingVec.size(); textureIdx++)
Shannon Woods53a94a82014-06-24 15:20:36 -0400294 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800295 bindingVec[textureIdx].set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400296 }
297 }
Geoff Lang76b10c92014-09-05 16:28:14 -0400298 for (size_t samplerIdx = 0; samplerIdx < mSamplers.size(); samplerIdx++)
299 {
Jamie Madill4928b7c2017-06-20 12:57:39 -0400300 mSamplers[samplerIdx].set(context, nullptr);
Geoff Lang76b10c92014-09-05 16:28:14 -0400301 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400302
Xinghua Cao65ec0b22017-03-28 16:10:52 +0800303 for (auto &imageUnit : mImageUnits)
304 {
305 imageUnit.texture.set(context, nullptr);
306 imageUnit.level = 0;
307 imageUnit.layered = false;
308 imageUnit.layer = 0;
309 imageUnit.access = GL_READ_ONLY;
310 imageUnit.format = GL_R32UI;
311 }
312
Jamie Madill4928b7c2017-06-20 12:57:39 -0400313 mRenderbuffer.set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400314
Corentin Wallez336129f2017-10-17 15:55:40 -0400315 for (auto type : angle::AllEnums<BufferBinding>())
316 {
Jamie Madillbf5177d2018-08-21 12:58:20 -0400317 UpdateBufferBinding(context, &mBoundBuffers[type], nullptr, type);
Corentin Wallez336129f2017-10-17 15:55:40 -0400318 }
319
Geoff Lang7dd2e102014-11-10 15:19:26 -0500320 if (mProgram)
321 {
Jamie Madill6c1f6712017-02-14 19:08:04 -0500322 mProgram->release(context);
Geoff Lang7dd2e102014-11-10 15:19:26 -0500323 }
Yunchao Hed7297bf2017-04-19 15:27:10 +0800324 mProgram = nullptr;
Geoff Lang7dd2e102014-11-10 15:19:26 -0500325
Yunchao Hea336b902017-08-02 16:05:21 +0800326 mProgramPipeline.set(context, nullptr);
327
James Darpiniane8a93c62018-01-04 18:02:24 -0800328 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -0400329 mTransformFeedback->onBindingChanged(context, false);
Jamie Madill4928b7c2017-06-20 12:57:39 -0400330 mTransformFeedback.set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400331
Corentin Wallezad3ae902018-03-09 13:40:42 -0500332 for (QueryType type : angle::AllEnums<QueryType>())
Shannon Woods53a94a82014-06-24 15:20:36 -0400333 {
Corentin Wallezad3ae902018-03-09 13:40:42 -0500334 mActiveQueries[type].set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400335 }
336
Corentin Wallez336129f2017-10-17 15:55:40 -0400337 for (auto &buf : mUniformBuffers)
Shannon Woods53a94a82014-06-24 15:20:36 -0400338 {
Jamie Madillbf5177d2018-08-21 12:58:20 -0400339 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::Uniform, 0, 0);
Shannon Woods53a94a82014-06-24 15:20:36 -0400340 }
341
Jiajia Qin6eafb042016-12-27 17:04:07 +0800342 for (auto &buf : mAtomicCounterBuffers)
343 {
Jamie Madillbf5177d2018-08-21 12:58:20 -0400344 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::AtomicCounter, 0, 0);
Jiajia Qin6eafb042016-12-27 17:04:07 +0800345 }
346
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800347 for (auto &buf : mShaderStorageBuffers)
348 {
Jamie Madillbf5177d2018-08-21 12:58:20 -0400349 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::ShaderStorage, 0, 0);
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800350 }
351
Sami Väisänene45e53b2016-05-25 10:36:04 +0300352 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixProj);
353 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixMV);
354 mPathStencilFunc = GL_ALWAYS;
355 mPathStencilRef = 0;
356 mPathStencilMask = std::numeric_limits<GLuint>::max();
357
Jamie Madill1b94d432015-08-07 13:23:23 -0400358 setAllDirtyBits();
Shannon Woods53a94a82014-06-24 15:20:36 -0400359}
360
Jamie Madille3bb6b72018-10-03 17:51:15 -0400361ANGLE_INLINE void State::unsetActiveTextures(ActiveTextureMask textureMask)
362{
363 // Unset any relevant bound textures.
364 for (size_t textureIndex : mProgram->getActiveSamplersMask())
365 {
366 mActiveTexturesCache[textureIndex] = nullptr;
367 mCompleteTextureBindings[textureIndex].reset();
368 }
369}
370
Jamie Madill6f755b22018-10-09 12:48:54 -0400371ANGLE_INLINE angle::Result State::updateActiveTexture(const Context *context,
372 size_t textureIndex,
373 Texture *texture)
Jamie Madille3bb6b72018-10-03 17:51:15 -0400374{
375 const Sampler *sampler = mSamplers[textureIndex].get();
376
377 if (!texture)
378 {
379 mActiveTexturesCache[textureIndex] = nullptr;
380 mCompleteTextureBindings[textureIndex].bind(nullptr);
Jamie Madill6f755b22018-10-09 12:48:54 -0400381 return angle::Result::Continue();
Jamie Madille3bb6b72018-10-03 17:51:15 -0400382 }
383
Jamie Madill31116732018-10-09 18:30:01 -0400384 mCompleteTextureBindings[textureIndex].bind(texture->getImplementation());
Jamie Madille3bb6b72018-10-03 17:51:15 -0400385
386 if (!texture->isSamplerComplete(context, sampler))
387 {
388 mActiveTexturesCache[textureIndex] = nullptr;
Jamie Madill6f755b22018-10-09 12:48:54 -0400389 return angle::Result::Continue();
Jamie Madille3bb6b72018-10-03 17:51:15 -0400390 }
391
392 mActiveTexturesCache[textureIndex] = texture;
393
394 if (texture->hasAnyDirtyBit())
395 {
396 ANGLE_TRY(texture->syncState(context));
397 }
398
399 if (texture->initState() == InitState::MayNeedInit)
400 {
401 mCachedTexturesInitState = InitState::MayNeedInit;
402 }
403
Jamie Madill6f755b22018-10-09 12:48:54 -0400404 return angle::Result::Continue();
Jamie Madille3bb6b72018-10-03 17:51:15 -0400405}
406
Shannon Woods53a94a82014-06-24 15:20:36 -0400407const RasterizerState &State::getRasterizerState() const
408{
409 return mRasterizer;
410}
411
412const BlendState &State::getBlendState() const
413{
414 return mBlend;
415}
416
417const DepthStencilState &State::getDepthStencilState() const
418{
419 return mDepthStencil;
420}
421
Jamie Madillf75ab352015-03-16 10:46:52 -0400422void State::setColorClearValue(float red, float green, float blue, float alpha)
Shannon Woods53a94a82014-06-24 15:20:36 -0400423{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700424 mColorClearValue.red = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400425 mColorClearValue.green = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700426 mColorClearValue.blue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400427 mColorClearValue.alpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400428 mDirtyBits.set(DIRTY_BIT_CLEAR_COLOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400429}
430
Jamie Madillf75ab352015-03-16 10:46:52 -0400431void State::setDepthClearValue(float depth)
Shannon Woods53a94a82014-06-24 15:20:36 -0400432{
433 mDepthClearValue = depth;
Jamie Madill1b94d432015-08-07 13:23:23 -0400434 mDirtyBits.set(DIRTY_BIT_CLEAR_DEPTH);
Shannon Woods53a94a82014-06-24 15:20:36 -0400435}
436
Jamie Madillf75ab352015-03-16 10:46:52 -0400437void State::setStencilClearValue(int stencil)
Shannon Woods53a94a82014-06-24 15:20:36 -0400438{
439 mStencilClearValue = stencil;
Jamie Madill1b94d432015-08-07 13:23:23 -0400440 mDirtyBits.set(DIRTY_BIT_CLEAR_STENCIL);
Shannon Woods53a94a82014-06-24 15:20:36 -0400441}
442
Shannon Woods53a94a82014-06-24 15:20:36 -0400443void State::setColorMask(bool red, bool green, bool blue, bool alpha)
444{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700445 mBlend.colorMaskRed = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400446 mBlend.colorMaskGreen = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700447 mBlend.colorMaskBlue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400448 mBlend.colorMaskAlpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400449 mDirtyBits.set(DIRTY_BIT_COLOR_MASK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400450}
451
452void State::setDepthMask(bool mask)
453{
454 mDepthStencil.depthMask = mask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400455 mDirtyBits.set(DIRTY_BIT_DEPTH_MASK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400456}
457
458bool State::isRasterizerDiscardEnabled() const
459{
460 return mRasterizer.rasterizerDiscard;
461}
462
463void State::setRasterizerDiscard(bool enabled)
464{
465 mRasterizer.rasterizerDiscard = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400466 mDirtyBits.set(DIRTY_BIT_RASTERIZER_DISCARD_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400467}
468
469bool State::isCullFaceEnabled() const
470{
471 return mRasterizer.cullFace;
472}
473
474void State::setCullFace(bool enabled)
475{
476 mRasterizer.cullFace = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400477 mDirtyBits.set(DIRTY_BIT_CULL_FACE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400478}
479
Corentin Wallez2e568cf2017-09-18 17:05:22 -0400480void State::setCullMode(CullFaceMode mode)
Shannon Woods53a94a82014-06-24 15:20:36 -0400481{
482 mRasterizer.cullMode = mode;
Jamie Madill1b94d432015-08-07 13:23:23 -0400483 mDirtyBits.set(DIRTY_BIT_CULL_FACE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400484}
485
486void State::setFrontFace(GLenum front)
487{
488 mRasterizer.frontFace = front;
Jamie Madill1b94d432015-08-07 13:23:23 -0400489 mDirtyBits.set(DIRTY_BIT_FRONT_FACE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400490}
491
492bool State::isDepthTestEnabled() const
493{
494 return mDepthStencil.depthTest;
495}
496
497void State::setDepthTest(bool enabled)
498{
499 mDepthStencil.depthTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400500 mDirtyBits.set(DIRTY_BIT_DEPTH_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400501}
502
503void State::setDepthFunc(GLenum depthFunc)
504{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700505 mDepthStencil.depthFunc = depthFunc;
506 mDirtyBits.set(DIRTY_BIT_DEPTH_FUNC);
Shannon Woods53a94a82014-06-24 15:20:36 -0400507}
508
509void State::setDepthRange(float zNear, float zFar)
510{
511 mNearZ = zNear;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700512 mFarZ = zFar;
Jamie Madill1b94d432015-08-07 13:23:23 -0400513 mDirtyBits.set(DIRTY_BIT_DEPTH_RANGE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400514}
515
Geoff Langd42f5b82015-04-16 14:03:29 -0400516float State::getNearPlane() const
Shannon Woods53a94a82014-06-24 15:20:36 -0400517{
Geoff Langd42f5b82015-04-16 14:03:29 -0400518 return mNearZ;
519}
520
521float State::getFarPlane() const
522{
523 return mFarZ;
Shannon Woods53a94a82014-06-24 15:20:36 -0400524}
525
526bool State::isBlendEnabled() const
527{
528 return mBlend.blend;
529}
530
531void State::setBlend(bool enabled)
532{
533 mBlend.blend = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400534 mDirtyBits.set(DIRTY_BIT_BLEND_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400535}
536
537void State::setBlendFactors(GLenum sourceRGB, GLenum destRGB, GLenum sourceAlpha, GLenum destAlpha)
538{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700539 mBlend.sourceBlendRGB = sourceRGB;
540 mBlend.destBlendRGB = destRGB;
Shannon Woods53a94a82014-06-24 15:20:36 -0400541 mBlend.sourceBlendAlpha = sourceAlpha;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700542 mBlend.destBlendAlpha = destAlpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400543 mDirtyBits.set(DIRTY_BIT_BLEND_FUNCS);
Shannon Woods53a94a82014-06-24 15:20:36 -0400544}
545
546void State::setBlendColor(float red, float green, float blue, float alpha)
547{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700548 mBlendColor.red = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400549 mBlendColor.green = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700550 mBlendColor.blue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400551 mBlendColor.alpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400552 mDirtyBits.set(DIRTY_BIT_BLEND_COLOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400553}
554
555void State::setBlendEquation(GLenum rgbEquation, GLenum alphaEquation)
556{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700557 mBlend.blendEquationRGB = rgbEquation;
Shannon Woods53a94a82014-06-24 15:20:36 -0400558 mBlend.blendEquationAlpha = alphaEquation;
Jamie Madill1b94d432015-08-07 13:23:23 -0400559 mDirtyBits.set(DIRTY_BIT_BLEND_EQUATIONS);
Shannon Woods53a94a82014-06-24 15:20:36 -0400560}
561
562const ColorF &State::getBlendColor() const
563{
564 return mBlendColor;
565}
566
567bool State::isStencilTestEnabled() const
568{
569 return mDepthStencil.stencilTest;
570}
571
572void State::setStencilTest(bool enabled)
573{
574 mDepthStencil.stencilTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400575 mDirtyBits.set(DIRTY_BIT_STENCIL_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400576}
577
578void State::setStencilParams(GLenum stencilFunc, GLint stencilRef, GLuint stencilMask)
579{
580 mDepthStencil.stencilFunc = stencilFunc;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700581 mStencilRef = (stencilRef > 0) ? stencilRef : 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400582 mDepthStencil.stencilMask = stencilMask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400583 mDirtyBits.set(DIRTY_BIT_STENCIL_FUNCS_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400584}
585
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700586void State::setStencilBackParams(GLenum stencilBackFunc,
587 GLint stencilBackRef,
588 GLuint stencilBackMask)
Shannon Woods53a94a82014-06-24 15:20:36 -0400589{
590 mDepthStencil.stencilBackFunc = stencilBackFunc;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700591 mStencilBackRef = (stencilBackRef > 0) ? stencilBackRef : 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400592 mDepthStencil.stencilBackMask = stencilBackMask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400593 mDirtyBits.set(DIRTY_BIT_STENCIL_FUNCS_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400594}
595
596void State::setStencilWritemask(GLuint stencilWritemask)
597{
598 mDepthStencil.stencilWritemask = stencilWritemask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400599 mDirtyBits.set(DIRTY_BIT_STENCIL_WRITEMASK_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400600}
601
602void State::setStencilBackWritemask(GLuint stencilBackWritemask)
603{
604 mDepthStencil.stencilBackWritemask = stencilBackWritemask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400605 mDirtyBits.set(DIRTY_BIT_STENCIL_WRITEMASK_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400606}
607
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700608void State::setStencilOperations(GLenum stencilFail,
609 GLenum stencilPassDepthFail,
610 GLenum stencilPassDepthPass)
Shannon Woods53a94a82014-06-24 15:20:36 -0400611{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700612 mDepthStencil.stencilFail = stencilFail;
Shannon Woods53a94a82014-06-24 15:20:36 -0400613 mDepthStencil.stencilPassDepthFail = stencilPassDepthFail;
614 mDepthStencil.stencilPassDepthPass = stencilPassDepthPass;
Jamie Madill1b94d432015-08-07 13:23:23 -0400615 mDirtyBits.set(DIRTY_BIT_STENCIL_OPS_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400616}
617
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700618void State::setStencilBackOperations(GLenum stencilBackFail,
619 GLenum stencilBackPassDepthFail,
620 GLenum stencilBackPassDepthPass)
Shannon Woods53a94a82014-06-24 15:20:36 -0400621{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700622 mDepthStencil.stencilBackFail = stencilBackFail;
Shannon Woods53a94a82014-06-24 15:20:36 -0400623 mDepthStencil.stencilBackPassDepthFail = stencilBackPassDepthFail;
624 mDepthStencil.stencilBackPassDepthPass = stencilBackPassDepthPass;
Jamie Madill1b94d432015-08-07 13:23:23 -0400625 mDirtyBits.set(DIRTY_BIT_STENCIL_OPS_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400626}
627
628GLint State::getStencilRef() const
629{
630 return mStencilRef;
631}
632
633GLint State::getStencilBackRef() const
634{
635 return mStencilBackRef;
636}
637
638bool State::isPolygonOffsetFillEnabled() const
639{
640 return mRasterizer.polygonOffsetFill;
641}
642
643void State::setPolygonOffsetFill(bool enabled)
644{
Jamie Madill1b94d432015-08-07 13:23:23 -0400645 mRasterizer.polygonOffsetFill = enabled;
646 mDirtyBits.set(DIRTY_BIT_POLYGON_OFFSET_FILL_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400647}
648
649void State::setPolygonOffsetParams(GLfloat factor, GLfloat units)
650{
651 // An application can pass NaN values here, so handle this gracefully
652 mRasterizer.polygonOffsetFactor = factor != factor ? 0.0f : factor;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700653 mRasterizer.polygonOffsetUnits = units != units ? 0.0f : units;
Jamie Madill1b94d432015-08-07 13:23:23 -0400654 mDirtyBits.set(DIRTY_BIT_POLYGON_OFFSET);
Shannon Woods53a94a82014-06-24 15:20:36 -0400655}
656
657bool State::isSampleAlphaToCoverageEnabled() const
658{
659 return mBlend.sampleAlphaToCoverage;
660}
661
662void State::setSampleAlphaToCoverage(bool enabled)
663{
664 mBlend.sampleAlphaToCoverage = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400665 mDirtyBits.set(DIRTY_BIT_SAMPLE_ALPHA_TO_COVERAGE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400666}
667
668bool State::isSampleCoverageEnabled() const
669{
670 return mSampleCoverage;
671}
672
673void State::setSampleCoverage(bool enabled)
674{
675 mSampleCoverage = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400676 mDirtyBits.set(DIRTY_BIT_SAMPLE_COVERAGE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400677}
678
679void State::setSampleCoverageParams(GLclampf value, bool invert)
680{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700681 mSampleCoverageValue = value;
Shannon Woods53a94a82014-06-24 15:20:36 -0400682 mSampleCoverageInvert = invert;
Jamie Madill1b94d432015-08-07 13:23:23 -0400683 mDirtyBits.set(DIRTY_BIT_SAMPLE_COVERAGE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400684}
685
Geoff Lang0fbb6002015-04-16 11:11:53 -0400686GLclampf State::getSampleCoverageValue() const
Shannon Woods53a94a82014-06-24 15:20:36 -0400687{
Geoff Lang0fbb6002015-04-16 11:11:53 -0400688 return mSampleCoverageValue;
689}
Shannon Woods53a94a82014-06-24 15:20:36 -0400690
Geoff Lang0fbb6002015-04-16 11:11:53 -0400691bool State::getSampleCoverageInvert() const
692{
693 return mSampleCoverageInvert;
Shannon Woods53a94a82014-06-24 15:20:36 -0400694}
695
Jiawei Shaodb342272017-09-27 10:21:45 +0800696bool State::isSampleMaskEnabled() const
697{
698 return mSampleMask;
699}
700
701void State::setSampleMaskEnabled(bool enabled)
702{
703 mSampleMask = enabled;
704 mDirtyBits.set(DIRTY_BIT_SAMPLE_MASK_ENABLED);
705}
706
707void State::setSampleMaskParams(GLuint maskNumber, GLbitfield mask)
708{
709 ASSERT(maskNumber < mMaxSampleMaskWords);
710 mSampleMaskValues[maskNumber] = mask;
Jamie Madillc67323a2017-11-02 23:11:41 -0400711 // TODO(jmadill): Use a child dirty bit if we ever use more than two words.
712 mDirtyBits.set(DIRTY_BIT_SAMPLE_MASK);
Jiawei Shaodb342272017-09-27 10:21:45 +0800713}
714
715GLbitfield State::getSampleMaskWord(GLuint maskNumber) const
716{
717 ASSERT(maskNumber < mMaxSampleMaskWords);
718 return mSampleMaskValues[maskNumber];
719}
720
721GLuint State::getMaxSampleMaskWords() const
722{
723 return mMaxSampleMaskWords;
724}
725
Sami Väisänen74c23472016-05-09 17:30:30 +0300726void State::setSampleAlphaToOne(bool enabled)
727{
728 mSampleAlphaToOne = enabled;
729 mDirtyBits.set(DIRTY_BIT_SAMPLE_ALPHA_TO_ONE);
730}
731
732bool State::isSampleAlphaToOneEnabled() const
733{
734 return mSampleAlphaToOne;
735}
736
737void State::setMultisampling(bool enabled)
738{
739 mMultiSampling = enabled;
740 mDirtyBits.set(DIRTY_BIT_MULTISAMPLING);
741}
742
743bool State::isMultisamplingEnabled() const
744{
745 return mMultiSampling;
746}
747
Shannon Woods53a94a82014-06-24 15:20:36 -0400748bool State::isScissorTestEnabled() const
749{
750 return mScissorTest;
751}
752
753void State::setScissorTest(bool enabled)
754{
755 mScissorTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400756 mDirtyBits.set(DIRTY_BIT_SCISSOR_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400757}
758
759void State::setScissorParams(GLint x, GLint y, GLsizei width, GLsizei height)
760{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700761 mScissor.x = x;
762 mScissor.y = y;
763 mScissor.width = width;
Shannon Woods53a94a82014-06-24 15:20:36 -0400764 mScissor.height = height;
Jamie Madill1b94d432015-08-07 13:23:23 -0400765 mDirtyBits.set(DIRTY_BIT_SCISSOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400766}
767
768const Rectangle &State::getScissor() const
769{
770 return mScissor;
771}
772
773bool State::isDitherEnabled() const
774{
775 return mBlend.dither;
776}
777
778void State::setDither(bool enabled)
779{
780 mBlend.dither = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400781 mDirtyBits.set(DIRTY_BIT_DITHER_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400782}
783
Jamie Madillb4b53c52015-02-03 15:22:48 -0500784bool State::isPrimitiveRestartEnabled() const
785{
786 return mPrimitiveRestart;
787}
788
789void State::setPrimitiveRestart(bool enabled)
790{
791 mPrimitiveRestart = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400792 mDirtyBits.set(DIRTY_BIT_PRIMITIVE_RESTART_ENABLED);
Jamie Madillb4b53c52015-02-03 15:22:48 -0500793}
794
Shannon Woods53a94a82014-06-24 15:20:36 -0400795void State::setEnableFeature(GLenum feature, bool enabled)
796{
797 switch (feature)
798 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700799 case GL_MULTISAMPLE_EXT:
800 setMultisampling(enabled);
801 break;
802 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
803 setSampleAlphaToOne(enabled);
804 break;
805 case GL_CULL_FACE:
806 setCullFace(enabled);
807 break;
808 case GL_POLYGON_OFFSET_FILL:
809 setPolygonOffsetFill(enabled);
810 break;
811 case GL_SAMPLE_ALPHA_TO_COVERAGE:
812 setSampleAlphaToCoverage(enabled);
813 break;
814 case GL_SAMPLE_COVERAGE:
815 setSampleCoverage(enabled);
816 break;
817 case GL_SCISSOR_TEST:
818 setScissorTest(enabled);
819 break;
820 case GL_STENCIL_TEST:
821 setStencilTest(enabled);
822 break;
823 case GL_DEPTH_TEST:
824 setDepthTest(enabled);
825 break;
826 case GL_BLEND:
827 setBlend(enabled);
828 break;
829 case GL_DITHER:
830 setDither(enabled);
831 break;
832 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
833 setPrimitiveRestart(enabled);
834 break;
835 case GL_RASTERIZER_DISCARD:
836 setRasterizerDiscard(enabled);
837 break;
838 case GL_SAMPLE_MASK:
839 setSampleMaskEnabled(enabled);
840 break;
841 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
842 mDebug.setOutputSynchronous(enabled);
843 break;
844 case GL_DEBUG_OUTPUT:
845 mDebug.setOutputEnabled(enabled);
846 break;
847 case GL_FRAMEBUFFER_SRGB_EXT:
848 setFramebufferSRGB(enabled);
849 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -0700850
851 // GLES1 emulation
852 case GL_ALPHA_TEST:
853 mGLES1State.mAlphaTestEnabled = enabled;
854 break;
Lingfeng Yang23dc90b2018-04-23 09:01:49 -0700855 case GL_TEXTURE_2D:
856 mGLES1State.mTexUnitEnables[mActiveSampler].set(TextureType::_2D, enabled);
857 break;
858 case GL_TEXTURE_CUBE_MAP:
859 mGLES1State.mTexUnitEnables[mActiveSampler].set(TextureType::CubeMap, enabled);
860 break;
Lingfeng Yangd0febe72018-05-17 22:36:52 -0700861 case GL_LIGHTING:
862 mGLES1State.mLightingEnabled = enabled;
863 break;
864 case GL_LIGHT0:
865 case GL_LIGHT1:
866 case GL_LIGHT2:
867 case GL_LIGHT3:
868 case GL_LIGHT4:
869 case GL_LIGHT5:
870 case GL_LIGHT6:
871 case GL_LIGHT7:
872 mGLES1State.mLights[feature - GL_LIGHT0].enabled = enabled;
873 break;
874 case GL_NORMALIZE:
875 mGLES1State.mNormalizeEnabled = enabled;
876 break;
877 case GL_RESCALE_NORMAL:
878 mGLES1State.mRescaleNormalEnabled = enabled;
879 break;
880 case GL_COLOR_MATERIAL:
881 mGLES1State.mColorMaterialEnabled = enabled;
882 break;
Lingfeng Yang060088a2018-05-30 20:40:57 -0700883 case GL_CLIP_PLANE0:
884 case GL_CLIP_PLANE1:
885 case GL_CLIP_PLANE2:
886 case GL_CLIP_PLANE3:
887 case GL_CLIP_PLANE4:
888 case GL_CLIP_PLANE5:
889 mGLES1State.mClipPlanes[feature - GL_CLIP_PLANE0].enabled = enabled;
890 break;
Lingfeng Yang7ba3f422018-06-01 09:43:04 -0700891 case GL_FOG:
892 mGLES1State.mFogEnabled = enabled;
893 break;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -0700894 case GL_POINT_SMOOTH:
895 mGLES1State.mPointSmoothEnabled = enabled;
896 break;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -0700897 case GL_LINE_SMOOTH:
898 mGLES1State.mLineSmoothEnabled = enabled;
899 break;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -0700900 case GL_POINT_SPRITE_OES:
901 mGLES1State.mPointSpriteEnabled = enabled;
902 break;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -0700903 case GL_COLOR_LOGIC_OP:
904 mGLES1State.mLogicOpEnabled = enabled;
905 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700906 default:
907 UNREACHABLE();
Shannon Woods53a94a82014-06-24 15:20:36 -0400908 }
909}
910
Jamie Madilldfde6ab2016-06-09 07:07:18 -0700911bool State::getEnableFeature(GLenum feature) const
Shannon Woods53a94a82014-06-24 15:20:36 -0400912{
913 switch (feature)
914 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700915 case GL_MULTISAMPLE_EXT:
916 return isMultisamplingEnabled();
917 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
918 return isSampleAlphaToOneEnabled();
919 case GL_CULL_FACE:
920 return isCullFaceEnabled();
921 case GL_POLYGON_OFFSET_FILL:
922 return isPolygonOffsetFillEnabled();
923 case GL_SAMPLE_ALPHA_TO_COVERAGE:
924 return isSampleAlphaToCoverageEnabled();
925 case GL_SAMPLE_COVERAGE:
926 return isSampleCoverageEnabled();
927 case GL_SCISSOR_TEST:
928 return isScissorTestEnabled();
929 case GL_STENCIL_TEST:
930 return isStencilTestEnabled();
931 case GL_DEPTH_TEST:
932 return isDepthTestEnabled();
933 case GL_BLEND:
934 return isBlendEnabled();
935 case GL_DITHER:
936 return isDitherEnabled();
937 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
938 return isPrimitiveRestartEnabled();
939 case GL_RASTERIZER_DISCARD:
940 return isRasterizerDiscardEnabled();
941 case GL_SAMPLE_MASK:
942 return isSampleMaskEnabled();
943 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
944 return mDebug.isOutputSynchronous();
945 case GL_DEBUG_OUTPUT:
946 return mDebug.isOutputEnabled();
947 case GL_BIND_GENERATES_RESOURCE_CHROMIUM:
948 return isBindGeneratesResourceEnabled();
949 case GL_CLIENT_ARRAYS_ANGLE:
950 return areClientArraysEnabled();
951 case GL_FRAMEBUFFER_SRGB_EXT:
952 return getFramebufferSRGB();
953 case GL_ROBUST_RESOURCE_INITIALIZATION_ANGLE:
954 return mRobustResourceInit;
955 case GL_PROGRAM_CACHE_ENABLED_ANGLE:
956 return mProgramBinaryCacheEnabled;
Jamie Madillc43be722017-07-13 16:22:14 -0400957
Lingfeng Yang13b708f2018-03-21 12:14:10 -0700958 // GLES1 emulation
959 case GL_ALPHA_TEST:
960 return mGLES1State.mAlphaTestEnabled;
Lingfeng Yang01074432018-04-16 10:19:51 -0700961 case GL_VERTEX_ARRAY:
962 return mGLES1State.mVertexArrayEnabled;
963 case GL_NORMAL_ARRAY:
964 return mGLES1State.mNormalArrayEnabled;
965 case GL_COLOR_ARRAY:
966 return mGLES1State.mColorArrayEnabled;
967 case GL_POINT_SIZE_ARRAY_OES:
968 return mGLES1State.mPointSizeArrayEnabled;
969 case GL_TEXTURE_COORD_ARRAY:
970 return mGLES1State.mTexCoordArrayEnabled[mGLES1State.mClientActiveTexture];
Lingfeng Yang23dc90b2018-04-23 09:01:49 -0700971 case GL_TEXTURE_2D:
972 return mGLES1State.mTexUnitEnables[mActiveSampler].test(TextureType::_2D);
973 case GL_TEXTURE_CUBE_MAP:
974 return mGLES1State.mTexUnitEnables[mActiveSampler].test(TextureType::CubeMap);
Lingfeng Yangd0febe72018-05-17 22:36:52 -0700975 case GL_LIGHTING:
976 return mGLES1State.mLightingEnabled;
977 case GL_LIGHT0:
978 case GL_LIGHT1:
979 case GL_LIGHT2:
980 case GL_LIGHT3:
981 case GL_LIGHT4:
982 case GL_LIGHT5:
983 case GL_LIGHT6:
984 case GL_LIGHT7:
985 return mGLES1State.mLights[feature - GL_LIGHT0].enabled;
986 case GL_NORMALIZE:
987 return mGLES1State.mNormalizeEnabled;
988 case GL_RESCALE_NORMAL:
989 return mGLES1State.mRescaleNormalEnabled;
990 case GL_COLOR_MATERIAL:
991 return mGLES1State.mColorMaterialEnabled;
Lingfeng Yang060088a2018-05-30 20:40:57 -0700992 case GL_CLIP_PLANE0:
993 case GL_CLIP_PLANE1:
994 case GL_CLIP_PLANE2:
995 case GL_CLIP_PLANE3:
996 case GL_CLIP_PLANE4:
997 case GL_CLIP_PLANE5:
998 return mGLES1State.mClipPlanes[feature - GL_CLIP_PLANE0].enabled;
Lingfeng Yang7ba3f422018-06-01 09:43:04 -0700999 case GL_FOG:
1000 return mGLES1State.mFogEnabled;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -07001001 case GL_POINT_SMOOTH:
1002 return mGLES1State.mPointSmoothEnabled;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -07001003 case GL_LINE_SMOOTH:
1004 return mGLES1State.mLineSmoothEnabled;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -07001005 case GL_POINT_SPRITE_OES:
1006 return mGLES1State.mPointSpriteEnabled;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -07001007 case GL_COLOR_LOGIC_OP:
1008 return mGLES1State.mLogicOpEnabled;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001009 default:
1010 UNREACHABLE();
1011 return false;
Shannon Woods53a94a82014-06-24 15:20:36 -04001012 }
1013}
1014
1015void State::setLineWidth(GLfloat width)
1016{
1017 mLineWidth = width;
Jamie Madill1b94d432015-08-07 13:23:23 -04001018 mDirtyBits.set(DIRTY_BIT_LINE_WIDTH);
Shannon Woods53a94a82014-06-24 15:20:36 -04001019}
1020
Geoff Lang4b3f4162015-04-16 13:22:05 -04001021float State::getLineWidth() const
1022{
1023 return mLineWidth;
1024}
1025
Shannon Woods53a94a82014-06-24 15:20:36 -04001026void State::setGenerateMipmapHint(GLenum hint)
1027{
1028 mGenerateMipmapHint = hint;
Jamie Madill1b94d432015-08-07 13:23:23 -04001029 mDirtyBits.set(DIRTY_BIT_GENERATE_MIPMAP_HINT);
Shannon Woods53a94a82014-06-24 15:20:36 -04001030}
1031
1032void State::setFragmentShaderDerivativeHint(GLenum hint)
1033{
1034 mFragmentShaderDerivativeHint = hint;
Jamie Madill1b94d432015-08-07 13:23:23 -04001035 mDirtyBits.set(DIRTY_BIT_SHADER_DERIVATIVE_HINT);
Shannon Woods53a94a82014-06-24 15:20:36 -04001036 // TODO: Propagate the hint to shader translator so we can write
1037 // ddx, ddx_coarse, or ddx_fine depending on the hint.
1038 // Ignore for now. It is valid for implementations to ignore hint.
1039}
1040
Geoff Langfeb8c682017-02-13 16:07:35 -05001041bool State::areClientArraysEnabled() const
1042{
1043 return mClientArraysEnabled;
1044}
1045
Shannon Woods53a94a82014-06-24 15:20:36 -04001046void State::setViewportParams(GLint x, GLint y, GLsizei width, GLsizei height)
1047{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001048 mViewport.x = x;
1049 mViewport.y = y;
1050 mViewport.width = width;
Shannon Woods53a94a82014-06-24 15:20:36 -04001051 mViewport.height = height;
Jamie Madill1b94d432015-08-07 13:23:23 -04001052 mDirtyBits.set(DIRTY_BIT_VIEWPORT);
Shannon Woods53a94a82014-06-24 15:20:36 -04001053}
1054
1055const Rectangle &State::getViewport() const
1056{
1057 return mViewport;
1058}
1059
1060void State::setActiveSampler(unsigned int active)
1061{
1062 mActiveSampler = active;
1063}
1064
1065unsigned int State::getActiveSampler() const
1066{
Cooper Partin4d61f7e2015-08-12 10:56:50 -07001067 return static_cast<unsigned int>(mActiveSampler);
Shannon Woods53a94a82014-06-24 15:20:36 -04001068}
1069
Jamie Madill14246812018-10-03 17:51:16 -04001070Error State::setSamplerTexture(const Context *context, TextureType type, Texture *texture)
Shannon Woods53a94a82014-06-24 15:20:36 -04001071{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001072 mSamplerTextures[type][mActiveSampler].set(context, texture);
Jamie Madill14246812018-10-03 17:51:16 -04001073
1074 if (mProgram && mProgram->getActiveSamplersMask()[mActiveSampler] &&
1075 mProgram->getActiveSamplerTypes()[mActiveSampler] == type)
1076 {
1077 ANGLE_TRY(updateActiveTexture(context, mActiveSampler, texture));
1078 }
1079
Jamie Madill81c2e252017-09-09 23:32:46 -04001080 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
Jamie Madill14246812018-10-03 17:51:16 -04001081
1082 return NoError();
Shannon Woods53a94a82014-06-24 15:20:36 -04001083}
1084
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001085Texture *State::getTargetTexture(TextureType type) const
Jamie Madillc29968b2016-01-20 11:17:23 -05001086{
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001087 return getSamplerTexture(static_cast<unsigned int>(mActiveSampler), type);
Jamie Madillc29968b2016-01-20 11:17:23 -05001088}
1089
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001090GLuint State::getSamplerTextureId(unsigned int sampler, TextureType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001091{
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001092 ASSERT(sampler < mSamplerTextures[type].size());
1093 return mSamplerTextures[type][sampler].id();
Shannon Woods53a94a82014-06-24 15:20:36 -04001094}
1095
Jamie Madilla02315b2017-02-23 14:14:47 -05001096void State::detachTexture(const Context *context, const TextureMap &zeroTextures, GLuint texture)
Shannon Woods53a94a82014-06-24 15:20:36 -04001097{
1098 // Textures have a detach method on State rather than a simple
1099 // removeBinding, because the zero/null texture objects are managed
1100 // separately, and don't have to go through the Context's maps or
1101 // the ResourceManager.
1102
1103 // [OpenGL ES 2.0.24] section 3.8 page 84:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001104 // If a texture object is deleted, it is as if all texture units which are bound to that texture
1105 // object are rebound to texture object zero
Shannon Woods53a94a82014-06-24 15:20:36 -04001106
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001107 for (TextureType type : angle::AllEnums<TextureType>())
Shannon Woods53a94a82014-06-24 15:20:36 -04001108 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001109 TextureBindingVector &textureVector = mSamplerTextures[type];
Jamie Madill81c2e252017-09-09 23:32:46 -04001110 for (BindingPointer<Texture> &binding : textureVector)
Shannon Woods53a94a82014-06-24 15:20:36 -04001111 {
Geoff Lang76b10c92014-09-05 16:28:14 -04001112 if (binding.id() == texture)
Shannon Woods53a94a82014-06-24 15:20:36 -04001113 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001114 Texture *zeroTexture = zeroTextures[type].get();
1115 ASSERT(zeroTexture != nullptr);
Jamie Madille6382c32014-11-07 15:05:26 -05001116 // Zero textures are the "default" textures instead of NULL
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001117 binding.set(context, zeroTexture);
Jamie Madill81c2e252017-09-09 23:32:46 -04001118 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
Shannon Woods53a94a82014-06-24 15:20:36 -04001119 }
1120 }
1121 }
1122
Xinghua Cao65ec0b22017-03-28 16:10:52 +08001123 for (auto &bindingImageUnit : mImageUnits)
1124 {
1125 if (bindingImageUnit.texture.id() == texture)
1126 {
1127 bindingImageUnit.texture.set(context, nullptr);
1128 bindingImageUnit.level = 0;
1129 bindingImageUnit.layered = false;
1130 bindingImageUnit.layer = 0;
1131 bindingImageUnit.access = GL_READ_ONLY;
1132 bindingImageUnit.format = GL_R32UI;
1133 break;
1134 }
1135 }
1136
Shannon Woods53a94a82014-06-24 15:20:36 -04001137 // [OpenGL ES 2.0.24] section 4.4 page 112:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001138 // If a texture object is deleted while its image is attached to the currently bound
1139 // framebuffer, then it is as if Texture2DAttachment had been called, with a texture of 0, for
1140 // each attachment point to which this image was attached in the currently bound framebuffer.
Shannon Woods53a94a82014-06-24 15:20:36 -04001141
Jamie Madill8693bdb2017-09-02 15:32:14 -04001142 if (mReadFramebuffer && mReadFramebuffer->detachTexture(context, texture))
Shannon Woods53a94a82014-06-24 15:20:36 -04001143 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001144 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
Shannon Woods53a94a82014-06-24 15:20:36 -04001145 }
1146
Jamie Madill8693bdb2017-09-02 15:32:14 -04001147 if (mDrawFramebuffer && mDrawFramebuffer->detachTexture(context, texture))
Shannon Woods53a94a82014-06-24 15:20:36 -04001148 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001149 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
Shannon Woods53a94a82014-06-24 15:20:36 -04001150 }
1151}
1152
Jamie Madill4928b7c2017-06-20 12:57:39 -04001153void State::initializeZeroTextures(const Context *context, const TextureMap &zeroTextures)
Jamie Madille6382c32014-11-07 15:05:26 -05001154{
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001155 for (TextureType type : angle::AllEnums<TextureType>())
Jamie Madille6382c32014-11-07 15:05:26 -05001156 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001157 for (size_t textureUnit = 0; textureUnit < mSamplerTextures[type].size(); ++textureUnit)
Jamie Madille6382c32014-11-07 15:05:26 -05001158 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001159 mSamplerTextures[type][textureUnit].set(context, zeroTextures[type].get());
Jamie Madille6382c32014-11-07 15:05:26 -05001160 }
1161 }
1162}
1163
Jamie Madill4928b7c2017-06-20 12:57:39 -04001164void State::setSamplerBinding(const Context *context, GLuint textureUnit, Sampler *sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001165{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001166 mSamplers[textureUnit].set(context, sampler);
Jamie Madill81c2e252017-09-09 23:32:46 -04001167 mDirtyBits.set(DIRTY_BIT_SAMPLER_BINDINGS);
1168 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Jamie Madille25b8002018-09-20 13:39:49 -04001169 // This is overly conservative as it assumes the sampler has never been bound.
1170 setSamplerDirty(textureUnit);
Shannon Woods53a94a82014-06-24 15:20:36 -04001171}
1172
1173GLuint State::getSamplerId(GLuint textureUnit) const
1174{
Geoff Lang76b10c92014-09-05 16:28:14 -04001175 ASSERT(textureUnit < mSamplers.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001176 return mSamplers[textureUnit].id();
1177}
1178
Jamie Madill4928b7c2017-06-20 12:57:39 -04001179void State::detachSampler(const Context *context, GLuint sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001180{
1181 // [OpenGL ES 3.0.2] section 3.8.2 pages 123-124:
1182 // If a sampler object that is currently bound to one or more texture units is
1183 // deleted, it is as though BindSampler is called once for each texture unit to
1184 // which the sampler is bound, with unit set to the texture unit and sampler set to zero.
Jamie Madill81c2e252017-09-09 23:32:46 -04001185 for (BindingPointer<Sampler> &samplerBinding : mSamplers)
Shannon Woods53a94a82014-06-24 15:20:36 -04001186 {
Geoff Lang76b10c92014-09-05 16:28:14 -04001187 if (samplerBinding.id() == sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001188 {
Jamie Madill4928b7c2017-06-20 12:57:39 -04001189 samplerBinding.set(context, nullptr);
Jamie Madill81c2e252017-09-09 23:32:46 -04001190 mDirtyBits.set(DIRTY_BIT_SAMPLER_BINDINGS);
Shannon Woods53a94a82014-06-24 15:20:36 -04001191 }
1192 }
1193}
1194
Jamie Madill4928b7c2017-06-20 12:57:39 -04001195void State::setRenderbufferBinding(const Context *context, Renderbuffer *renderbuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001196{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001197 mRenderbuffer.set(context, renderbuffer);
Jamie Madill8693bdb2017-09-02 15:32:14 -04001198 mDirtyBits.set(DIRTY_BIT_RENDERBUFFER_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001199}
1200
1201GLuint State::getRenderbufferId() const
1202{
1203 return mRenderbuffer.id();
1204}
1205
Jamie Madilldfde6ab2016-06-09 07:07:18 -07001206Renderbuffer *State::getCurrentRenderbuffer() const
Shannon Woods53a94a82014-06-24 15:20:36 -04001207{
1208 return mRenderbuffer.get();
1209}
1210
Jamie Madilla02315b2017-02-23 14:14:47 -05001211void State::detachRenderbuffer(const Context *context, GLuint renderbuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001212{
1213 // [OpenGL ES 2.0.24] section 4.4 page 109:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001214 // If a renderbuffer that is currently bound to RENDERBUFFER is deleted, it is as though
1215 // BindRenderbuffer had been executed with the target RENDERBUFFER and name of zero.
Shannon Woods53a94a82014-06-24 15:20:36 -04001216
1217 if (mRenderbuffer.id() == renderbuffer)
1218 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001219 setRenderbufferBinding(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001220 }
1221
1222 // [OpenGL ES 2.0.24] section 4.4 page 111:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001223 // If a renderbuffer object is deleted while its image is attached to the currently bound
1224 // framebuffer, then it is as if FramebufferRenderbuffer had been called, with a renderbuffer of
1225 // 0, for each attachment point to which this image was attached in the currently bound
1226 // framebuffer.
Shannon Woods53a94a82014-06-24 15:20:36 -04001227
1228 Framebuffer *readFramebuffer = mReadFramebuffer;
1229 Framebuffer *drawFramebuffer = mDrawFramebuffer;
1230
Jamie Madill8693bdb2017-09-02 15:32:14 -04001231 if (readFramebuffer && readFramebuffer->detachRenderbuffer(context, renderbuffer))
Shannon Woods53a94a82014-06-24 15:20:36 -04001232 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001233 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
Shannon Woods53a94a82014-06-24 15:20:36 -04001234 }
1235
1236 if (drawFramebuffer && drawFramebuffer != readFramebuffer)
1237 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001238 if (drawFramebuffer->detachRenderbuffer(context, renderbuffer))
1239 {
1240 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
1241 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001242 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001243}
1244
1245void State::setReadFramebufferBinding(Framebuffer *framebuffer)
1246{
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001247 if (mReadFramebuffer == framebuffer)
1248 return;
1249
Shannon Woods53a94a82014-06-24 15:20:36 -04001250 mReadFramebuffer = framebuffer;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001251 mDirtyBits.set(DIRTY_BIT_READ_FRAMEBUFFER_BINDING);
1252
1253 if (mReadFramebuffer && mReadFramebuffer->hasAnyDirtyBit())
1254 {
1255 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
1256 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001257}
1258
1259void State::setDrawFramebufferBinding(Framebuffer *framebuffer)
1260{
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001261 if (mDrawFramebuffer == framebuffer)
1262 return;
1263
Shannon Woods53a94a82014-06-24 15:20:36 -04001264 mDrawFramebuffer = framebuffer;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001265 mDirtyBits.set(DIRTY_BIT_DRAW_FRAMEBUFFER_BINDING);
1266
1267 if (mDrawFramebuffer && mDrawFramebuffer->hasAnyDirtyBit())
1268 {
1269 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
1270 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001271}
1272
1273Framebuffer *State::getTargetFramebuffer(GLenum target) const
1274{
1275 switch (target)
1276 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001277 case GL_READ_FRAMEBUFFER_ANGLE:
1278 return mReadFramebuffer;
1279 case GL_DRAW_FRAMEBUFFER_ANGLE:
1280 case GL_FRAMEBUFFER:
1281 return mDrawFramebuffer;
1282 default:
1283 UNREACHABLE();
Yunchao Hef81ce4a2017-04-24 10:49:17 +08001284 return nullptr;
Shannon Woods53a94a82014-06-24 15:20:36 -04001285 }
1286}
1287
Jamie Madill51f40ec2016-06-15 14:06:00 -04001288Framebuffer *State::getReadFramebuffer() const
Shannon Woods53a94a82014-06-24 15:20:36 -04001289{
1290 return mReadFramebuffer;
1291}
1292
Shannon Woods53a94a82014-06-24 15:20:36 -04001293bool State::removeReadFramebufferBinding(GLuint framebuffer)
1294{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001295 if (mReadFramebuffer != nullptr && mReadFramebuffer->id() == framebuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001296 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001297 setReadFramebufferBinding(nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001298 return true;
1299 }
1300
1301 return false;
1302}
1303
1304bool State::removeDrawFramebufferBinding(GLuint framebuffer)
1305{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001306 if (mReadFramebuffer != nullptr && mDrawFramebuffer->id() == framebuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001307 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001308 setDrawFramebufferBinding(nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001309 return true;
1310 }
1311
1312 return false;
1313}
1314
Jamie Madill7267aa62018-04-17 15:28:21 -04001315void State::setVertexArrayBinding(const Context *context, VertexArray *vertexArray)
Shannon Woods53a94a82014-06-24 15:20:36 -04001316{
James Darpiniane8a93c62018-01-04 18:02:24 -08001317 if (mVertexArray == vertexArray)
1318 return;
1319 if (mVertexArray)
Jamie Madillbf5177d2018-08-21 12:58:20 -04001320 mVertexArray->onBindingChanged(context, -1);
Shannon Woods53a94a82014-06-24 15:20:36 -04001321 mVertexArray = vertexArray;
James Darpiniane8a93c62018-01-04 18:02:24 -08001322 if (vertexArray)
Jamie Madillbf5177d2018-08-21 12:58:20 -04001323 vertexArray->onBindingChanged(context, 1);
Jamie Madill0b9e9032015-08-17 11:51:52 +00001324 mDirtyBits.set(DIRTY_BIT_VERTEX_ARRAY_BINDING);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001325
1326 if (mVertexArray && mVertexArray->hasAnyDirtyBit())
1327 {
1328 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1329 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001330}
1331
1332GLuint State::getVertexArrayId() const
1333{
Yunchao He4f285442017-04-21 12:15:49 +08001334 ASSERT(mVertexArray != nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001335 return mVertexArray->id();
1336}
1337
Jamie Madill7267aa62018-04-17 15:28:21 -04001338bool State::removeVertexArrayBinding(const Context *context, GLuint vertexArray)
Shannon Woods53a94a82014-06-24 15:20:36 -04001339{
James Darpiniane8a93c62018-01-04 18:02:24 -08001340 if (mVertexArray && mVertexArray->id() == vertexArray)
Shannon Woods53a94a82014-06-24 15:20:36 -04001341 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001342 mVertexArray->onBindingChanged(context, -1);
Yunchao Hed7297bf2017-04-19 15:27:10 +08001343 mVertexArray = nullptr;
Jamie Madill0b9e9032015-08-17 11:51:52 +00001344 mDirtyBits.set(DIRTY_BIT_VERTEX_ARRAY_BINDING);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001345 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001346 return true;
1347 }
1348
1349 return false;
1350}
1351
Jamie Madill4928b7c2017-06-20 12:57:39 -04001352void State::bindVertexBuffer(const Context *context,
1353 GLuint bindingIndex,
Shao80957d92017-02-20 21:25:59 +08001354 Buffer *boundBuffer,
1355 GLintptr offset,
1356 GLsizei stride)
1357{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001358 getVertexArray()->bindVertexBuffer(context, bindingIndex, boundBuffer, offset, stride);
Shao80957d92017-02-20 21:25:59 +08001359 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1360}
1361
Shaodde78e82017-05-22 14:13:27 +08001362void State::setVertexAttribBinding(const Context *context, GLuint attribIndex, GLuint bindingIndex)
Shao80957d92017-02-20 21:25:59 +08001363{
Shaodde78e82017-05-22 14:13:27 +08001364 getVertexArray()->setVertexAttribBinding(context, attribIndex, bindingIndex);
Shao80957d92017-02-20 21:25:59 +08001365 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1366}
1367
1368void State::setVertexAttribFormat(GLuint attribIndex,
1369 GLint size,
1370 GLenum type,
1371 bool normalized,
1372 bool pureInteger,
1373 GLuint relativeOffset)
1374{
1375 getVertexArray()->setVertexAttribFormat(attribIndex, size, type, normalized, pureInteger,
1376 relativeOffset);
1377 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1378}
1379
1380void State::setVertexBindingDivisor(GLuint bindingIndex, GLuint divisor)
1381{
1382 getVertexArray()->setVertexBindingDivisor(bindingIndex, divisor);
1383 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1384}
1385
Jamie Madill6f755b22018-10-09 12:48:54 -04001386angle::Result State::setProgram(const Context *context, Program *newProgram)
Shannon Woods53a94a82014-06-24 15:20:36 -04001387{
Geoff Lang7dd2e102014-11-10 15:19:26 -05001388 if (mProgram != newProgram)
Shannon Woods53a94a82014-06-24 15:20:36 -04001389 {
Geoff Lang7dd2e102014-11-10 15:19:26 -05001390 if (mProgram)
1391 {
Jamie Madille3bb6b72018-10-03 17:51:15 -04001392 unsetActiveTextures(mProgram->getActiveSamplersMask());
Jamie Madill6c1f6712017-02-14 19:08:04 -05001393 mProgram->release(context);
Geoff Lang7dd2e102014-11-10 15:19:26 -05001394 }
1395
1396 mProgram = newProgram;
1397
1398 if (mProgram)
1399 {
1400 newProgram->addRef();
Jamie Madille3bb6b72018-10-03 17:51:15 -04001401 ANGLE_TRY(onProgramExecutableChange(context, newProgram));
Geoff Lang7dd2e102014-11-10 15:19:26 -05001402 }
Jamie Madilldf836ff2018-10-01 10:36:24 -04001403
1404 // Note that rendering is undefined if glUseProgram(0) is called. But ANGLE will generate
1405 // an error if the app tries to draw in this case.
1406
Jamie Madilla779b612017-07-24 11:46:05 -04001407 mDirtyBits.set(DIRTY_BIT_PROGRAM_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001408 }
Jamie Madille3bb6b72018-10-03 17:51:15 -04001409
Jamie Madill6f755b22018-10-09 12:48:54 -04001410 return angle::Result::Continue();
Shannon Woods53a94a82014-06-24 15:20:36 -04001411}
1412
Jamie Madill4928b7c2017-06-20 12:57:39 -04001413void State::setTransformFeedbackBinding(const Context *context,
1414 TransformFeedback *transformFeedback)
Shannon Woods53a94a82014-06-24 15:20:36 -04001415{
James Darpiniane8a93c62018-01-04 18:02:24 -08001416 if (transformFeedback == mTransformFeedback.get())
1417 return;
1418 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -04001419 mTransformFeedback->onBindingChanged(context, false);
Jamie Madill4928b7c2017-06-20 12:57:39 -04001420 mTransformFeedback.set(context, transformFeedback);
James Darpiniane8a93c62018-01-04 18:02:24 -08001421 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -04001422 mTransformFeedback->onBindingChanged(context, true);
Geoff Langded79232017-11-28 15:21:11 -05001423 mDirtyBits.set(DIRTY_BIT_TRANSFORM_FEEDBACK_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001424}
1425
Jamie Madill4928b7c2017-06-20 12:57:39 -04001426bool State::removeTransformFeedbackBinding(const Context *context, GLuint transformFeedback)
Shannon Woods53a94a82014-06-24 15:20:36 -04001427{
1428 if (mTransformFeedback.id() == transformFeedback)
1429 {
James Darpiniane8a93c62018-01-04 18:02:24 -08001430 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -04001431 mTransformFeedback->onBindingChanged(context, false);
Jamie Madill4928b7c2017-06-20 12:57:39 -04001432 mTransformFeedback.set(context, nullptr);
Corentin Walleza2257da2016-04-19 16:43:12 -04001433 return true;
Shannon Woods53a94a82014-06-24 15:20:36 -04001434 }
Corentin Walleza2257da2016-04-19 16:43:12 -04001435
1436 return false;
Shannon Woods53a94a82014-06-24 15:20:36 -04001437}
1438
Yunchao Hea336b902017-08-02 16:05:21 +08001439void State::setProgramPipelineBinding(const Context *context, ProgramPipeline *pipeline)
1440{
1441 mProgramPipeline.set(context, pipeline);
1442}
1443
1444void State::detachProgramPipeline(const Context *context, GLuint pipeline)
1445{
1446 mProgramPipeline.set(context, nullptr);
1447}
1448
Corentin Wallezad3ae902018-03-09 13:40:42 -05001449bool State::isQueryActive(QueryType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001450{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001451 const Query *query = mActiveQueries[type].get();
1452 if (query != nullptr)
Shannon Woods53a94a82014-06-24 15:20:36 -04001453 {
Corentin Wallezad3ae902018-03-09 13:40:42 -05001454 return true;
1455 }
1456
1457 QueryType alternativeType;
1458 if (GetAlternativeQueryType(type, &alternativeType))
1459 {
1460 query = mActiveQueries[alternativeType].get();
1461 return query != nullptr;
Ian Ewell3ffd78b2016-01-22 16:09:42 -05001462 }
1463
1464 return false;
1465}
1466
1467bool State::isQueryActive(Query *query) const
1468{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001469 for (auto &queryPointer : mActiveQueries)
Ian Ewell3ffd78b2016-01-22 16:09:42 -05001470 {
Corentin Wallezad3ae902018-03-09 13:40:42 -05001471 if (queryPointer.get() == query)
Shannon Woods53a94a82014-06-24 15:20:36 -04001472 {
1473 return true;
1474 }
1475 }
1476
1477 return false;
1478}
1479
Corentin Wallezad3ae902018-03-09 13:40:42 -05001480void State::setActiveQuery(const Context *context, QueryType type, Query *query)
Shannon Woods53a94a82014-06-24 15:20:36 -04001481{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001482 mActiveQueries[type].set(context, query);
Shannon Woods53a94a82014-06-24 15:20:36 -04001483}
1484
Corentin Wallezad3ae902018-03-09 13:40:42 -05001485GLuint State::getActiveQueryId(QueryType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001486{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001487 const Query *query = getActiveQuery(type);
Shannon Woods53a94a82014-06-24 15:20:36 -04001488 return (query ? query->id() : 0u);
1489}
1490
Corentin Wallezad3ae902018-03-09 13:40:42 -05001491Query *State::getActiveQuery(QueryType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001492{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001493 return mActiveQueries[type].get();
Shannon Woods53a94a82014-06-24 15:20:36 -04001494}
1495
Corentin Wallez336129f2017-10-17 15:55:40 -04001496void State::setBufferBinding(const Context *context, BufferBinding target, Buffer *buffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001497{
Corentin Wallez336129f2017-10-17 15:55:40 -04001498 switch (target)
1499 {
1500 case BufferBinding::PixelPack:
Jamie Madillfcfd3382018-09-15 22:30:50 -04001501 UpdateNonTFBufferBinding(context, &mBoundBuffers[target], buffer);
Corentin Wallez336129f2017-10-17 15:55:40 -04001502 mDirtyBits.set(DIRTY_BIT_PACK_BUFFER_BINDING);
1503 break;
1504 case BufferBinding::PixelUnpack:
Jamie Madillfcfd3382018-09-15 22:30:50 -04001505 UpdateNonTFBufferBinding(context, &mBoundBuffers[target], buffer);
Corentin Wallez336129f2017-10-17 15:55:40 -04001506 mDirtyBits.set(DIRTY_BIT_UNPACK_BUFFER_BINDING);
1507 break;
1508 case BufferBinding::DrawIndirect:
Jamie Madillfcfd3382018-09-15 22:30:50 -04001509 UpdateNonTFBufferBinding(context, &mBoundBuffers[target], buffer);
Corentin Wallez336129f2017-10-17 15:55:40 -04001510 mDirtyBits.set(DIRTY_BIT_DRAW_INDIRECT_BUFFER_BINDING);
1511 break;
Qin Jiajiaa98a2812017-11-30 18:12:06 +08001512 case BufferBinding::DispatchIndirect:
Jamie Madillfcfd3382018-09-15 22:30:50 -04001513 UpdateNonTFBufferBinding(context, &mBoundBuffers[target], buffer);
Qin Jiajiaa98a2812017-11-30 18:12:06 +08001514 mDirtyBits.set(DIRTY_BIT_DISPATCH_INDIRECT_BUFFER_BINDING);
1515 break;
Corentin Wallez336129f2017-10-17 15:55:40 -04001516 case BufferBinding::ElementArray:
1517 getVertexArray()->setElementArrayBuffer(context, buffer);
1518 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1519 break;
Xinghua Cao10a4d432017-11-28 14:46:26 +08001520 case BufferBinding::ShaderStorage:
Jamie Madillfcfd3382018-09-15 22:30:50 -04001521 UpdateNonTFBufferBinding(context, &mBoundBuffers[target], buffer);
Xinghua Cao10a4d432017-11-28 14:46:26 +08001522 mDirtyBits.set(DIRTY_BIT_SHADER_STORAGE_BUFFER_BINDING);
1523 break;
jchen1099118c12018-09-10 16:28:51 +08001524 case BufferBinding::Uniform:
1525 UpdateBufferBinding(context, &mBoundBuffers[target], buffer, target);
1526 mDirtyBits.set(DIRTY_BIT_UNIFORM_BUFFER_BINDINGS);
1527 break;
1528 case BufferBinding::AtomicCounter:
1529 UpdateBufferBinding(context, &mBoundBuffers[target], buffer, target);
1530 mDirtyBits.set(DIRTY_BIT_ATOMIC_COUNTER_BUFFER_BINDING);
1531 break;
Corentin Wallez336129f2017-10-17 15:55:40 -04001532 default:
Jamie Madillbf5177d2018-08-21 12:58:20 -04001533 UpdateBufferBinding(context, &mBoundBuffers[target], buffer, target);
Corentin Wallez336129f2017-10-17 15:55:40 -04001534 break;
1535 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001536}
James Darpiniane8a93c62018-01-04 18:02:24 -08001537
Corentin Wallez336129f2017-10-17 15:55:40 -04001538void State::setIndexedBufferBinding(const Context *context,
1539 BufferBinding target,
1540 GLuint index,
1541 Buffer *buffer,
1542 GLintptr offset,
1543 GLsizeiptr size)
Jiajia Qin9d7d0b12016-11-29 16:30:31 +08001544{
Corentin Wallez336129f2017-10-17 15:55:40 -04001545 setBufferBinding(context, target, buffer);
Jiajia Qin9d7d0b12016-11-29 16:30:31 +08001546
Corentin Wallez336129f2017-10-17 15:55:40 -04001547 switch (target)
1548 {
1549 case BufferBinding::TransformFeedback:
1550 mTransformFeedback->bindIndexedBuffer(context, index, buffer, offset, size);
James Darpiniane8a93c62018-01-04 18:02:24 -08001551 setBufferBinding(context, target, buffer);
Corentin Wallez336129f2017-10-17 15:55:40 -04001552 break;
1553 case BufferBinding::Uniform:
Jamie Madillbf5177d2018-08-21 12:58:20 -04001554 UpdateIndexedBufferBinding(context, &mUniformBuffers[index], buffer, target, offset,
1555 size);
Corentin Wallez336129f2017-10-17 15:55:40 -04001556 break;
1557 case BufferBinding::AtomicCounter:
Jamie Madillbf5177d2018-08-21 12:58:20 -04001558 UpdateIndexedBufferBinding(context, &mAtomicCounterBuffers[index], buffer, target,
1559 offset, size);
Corentin Wallez336129f2017-10-17 15:55:40 -04001560 break;
1561 case BufferBinding::ShaderStorage:
Jamie Madillbf5177d2018-08-21 12:58:20 -04001562 UpdateIndexedBufferBinding(context, &mShaderStorageBuffers[index], buffer, target,
1563 offset, size);
Corentin Wallez336129f2017-10-17 15:55:40 -04001564 break;
1565 default:
1566 UNREACHABLE();
1567 break;
1568 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001569}
1570
Geoff Lang5d124a62015-09-15 13:03:27 -04001571const OffsetBindingPointer<Buffer> &State::getIndexedUniformBuffer(size_t index) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001572{
Shannon Woodsf3acaf92014-09-23 18:07:11 -04001573 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
Geoff Lang5d124a62015-09-15 13:03:27 -04001574 return mUniformBuffers[index];
Gregoire Payen de La Garanderie68694e92015-03-24 14:03:37 +00001575}
1576
Jiajia Qin6eafb042016-12-27 17:04:07 +08001577const OffsetBindingPointer<Buffer> &State::getIndexedAtomicCounterBuffer(size_t index) const
1578{
1579 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
1580 return mAtomicCounterBuffers[index];
1581}
1582
Jiajia Qinf546e7d2017-03-27 14:12:59 +08001583const OffsetBindingPointer<Buffer> &State::getIndexedShaderStorageBuffer(size_t index) const
1584{
1585 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
1586 return mShaderStorageBuffers[index];
1587}
1588
Corentin Wallez336129f2017-10-17 15:55:40 -04001589Buffer *State::getTargetBuffer(BufferBinding target) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001590{
1591 switch (target)
1592 {
Corentin Wallez336129f2017-10-17 15:55:40 -04001593 case BufferBinding::ElementArray:
1594 return getVertexArray()->getElementArrayBuffer().get();
Corentin Wallez336129f2017-10-17 15:55:40 -04001595 default:
1596 return mBoundBuffers[target].get();
Shannon Woods53a94a82014-06-24 15:20:36 -04001597 }
1598}
1599
James Darpinian4d9d4832018-03-13 12:43:28 -07001600void State::detachBuffer(const Context *context, const Buffer *buffer)
Yuly Novikov5807a532015-12-03 13:01:22 -05001601{
James Darpinian4d9d4832018-03-13 12:43:28 -07001602 if (!buffer->isBound())
1603 {
1604 return;
1605 }
1606 GLuint bufferName = buffer->id();
James Darpiniane8a93c62018-01-04 18:02:24 -08001607 for (auto target : angle::AllEnums<BufferBinding>())
Yuly Novikov5807a532015-12-03 13:01:22 -05001608 {
James Darpiniane8a93c62018-01-04 18:02:24 -08001609 if (mBoundBuffers[target].id() == bufferName)
Yuly Novikov5807a532015-12-03 13:01:22 -05001610 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001611 UpdateBufferBinding(context, &mBoundBuffers[target], nullptr, target);
Yuly Novikov5807a532015-12-03 13:01:22 -05001612 }
1613 }
1614
1615 TransformFeedback *curTransformFeedback = getCurrentTransformFeedback();
1616 if (curTransformFeedback)
1617 {
Jamie Madill4928b7c2017-06-20 12:57:39 -04001618 curTransformFeedback->detachBuffer(context, bufferName);
Yuly Novikov5807a532015-12-03 13:01:22 -05001619 }
1620
Jamie Madill4928b7c2017-06-20 12:57:39 -04001621 getVertexArray()->detachBuffer(context, bufferName);
James Darpiniane8a93c62018-01-04 18:02:24 -08001622
1623 for (auto &buf : mUniformBuffers)
1624 {
1625 if (buf.id() == bufferName)
1626 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001627 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::Uniform, 0, 0);
James Darpiniane8a93c62018-01-04 18:02:24 -08001628 }
1629 }
1630
1631 for (auto &buf : mAtomicCounterBuffers)
1632 {
1633 if (buf.id() == bufferName)
1634 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001635 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::AtomicCounter, 0, 0);
James Darpiniane8a93c62018-01-04 18:02:24 -08001636 }
1637 }
1638
1639 for (auto &buf : mShaderStorageBuffers)
1640 {
1641 if (buf.id() == bufferName)
1642 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001643 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::ShaderStorage, 0, 0);
James Darpiniane8a93c62018-01-04 18:02:24 -08001644 }
1645 }
Yuly Novikov5807a532015-12-03 13:01:22 -05001646}
1647
Shannon Woods53a94a82014-06-24 15:20:36 -04001648void State::setEnableVertexAttribArray(unsigned int attribNum, bool enabled)
1649{
1650 getVertexArray()->enableAttribute(attribNum, enabled);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001651 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001652}
1653
1654void State::setVertexAttribf(GLuint index, const GLfloat values[4])
1655{
Shannon Woods23e05002014-09-22 19:07:27 -04001656 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001657 mVertexAttribCurrentValues[index].setFloatValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001658 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1659 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001660 mCurrentValuesTypeMask.setIndex(GL_FLOAT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001661}
1662
1663void State::setVertexAttribu(GLuint index, const GLuint values[4])
1664{
Shannon Woods23e05002014-09-22 19:07:27 -04001665 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001666 mVertexAttribCurrentValues[index].setUnsignedIntValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001667 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1668 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001669 mCurrentValuesTypeMask.setIndex(GL_UNSIGNED_INT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001670}
1671
1672void State::setVertexAttribi(GLuint index, const GLint values[4])
1673{
Shannon Woods23e05002014-09-22 19:07:27 -04001674 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001675 mVertexAttribCurrentValues[index].setIntValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001676 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1677 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001678 mCurrentValuesTypeMask.setIndex(GL_INT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001679}
1680
Shaodde78e82017-05-22 14:13:27 +08001681void State::setVertexAttribPointer(const Context *context,
1682 unsigned int attribNum,
1683 Buffer *boundBuffer,
1684 GLint size,
1685 GLenum type,
1686 bool normalized,
1687 bool pureInteger,
1688 GLsizei stride,
1689 const void *pointer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001690{
Shaodde78e82017-05-22 14:13:27 +08001691 getVertexArray()->setVertexAttribPointer(context, attribNum, boundBuffer, size, type,
1692 normalized, pureInteger, stride, pointer);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001693 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Jamie Madill0b9e9032015-08-17 11:51:52 +00001694}
1695
Shaodde78e82017-05-22 14:13:27 +08001696void State::setVertexAttribDivisor(const Context *context, GLuint index, GLuint divisor)
Jamie Madill0b9e9032015-08-17 11:51:52 +00001697{
Shaodde78e82017-05-22 14:13:27 +08001698 getVertexArray()->setVertexAttribDivisor(context, index, divisor);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001699 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001700}
1701
Jamie Madill6de51852017-04-12 09:53:01 -04001702const VertexAttribCurrentValueData &State::getVertexAttribCurrentValue(size_t attribNum) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001703{
Jamie Madill6de51852017-04-12 09:53:01 -04001704 ASSERT(attribNum < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001705 return mVertexAttribCurrentValues[attribNum];
1706}
1707
Jamie Madillcac94a92017-11-10 10:09:32 -05001708const std::vector<VertexAttribCurrentValueData> &State::getVertexAttribCurrentValues() const
1709{
1710 return mVertexAttribCurrentValues;
1711}
1712
Shannon Woods53a94a82014-06-24 15:20:36 -04001713const void *State::getVertexAttribPointer(unsigned int attribNum) const
1714{
1715 return getVertexArray()->getVertexAttribute(attribNum).pointer;
1716}
1717
1718void State::setPackAlignment(GLint alignment)
1719{
1720 mPack.alignment = alignment;
Jamie Madillc67323a2017-11-02 23:11:41 -04001721 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001722}
1723
1724GLint State::getPackAlignment() const
1725{
1726 return mPack.alignment;
1727}
1728
1729void State::setPackReverseRowOrder(bool reverseRowOrder)
1730{
1731 mPack.reverseRowOrder = reverseRowOrder;
Jamie Madillc67323a2017-11-02 23:11:41 -04001732 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001733}
1734
1735bool State::getPackReverseRowOrder() const
1736{
1737 return mPack.reverseRowOrder;
1738}
1739
Minmin Gongadff67b2015-10-14 10:34:45 -04001740void State::setPackRowLength(GLint rowLength)
1741{
1742 mPack.rowLength = rowLength;
Jamie Madillc67323a2017-11-02 23:11:41 -04001743 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001744}
1745
1746GLint State::getPackRowLength() const
1747{
1748 return mPack.rowLength;
1749}
1750
1751void State::setPackSkipRows(GLint skipRows)
1752{
1753 mPack.skipRows = skipRows;
Jamie Madillc67323a2017-11-02 23:11:41 -04001754 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001755}
1756
1757GLint State::getPackSkipRows() const
1758{
1759 return mPack.skipRows;
1760}
1761
1762void State::setPackSkipPixels(GLint skipPixels)
1763{
1764 mPack.skipPixels = skipPixels;
Jamie Madillc67323a2017-11-02 23:11:41 -04001765 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001766}
1767
1768GLint State::getPackSkipPixels() const
1769{
1770 return mPack.skipPixels;
1771}
1772
Shannon Woods53a94a82014-06-24 15:20:36 -04001773const PixelPackState &State::getPackState() const
1774{
1775 return mPack;
1776}
1777
Jamie Madill87de3622015-03-16 10:41:44 -04001778PixelPackState &State::getPackState()
1779{
1780 return mPack;
1781}
1782
Shannon Woods53a94a82014-06-24 15:20:36 -04001783void State::setUnpackAlignment(GLint alignment)
1784{
1785 mUnpack.alignment = alignment;
Jamie Madillc67323a2017-11-02 23:11:41 -04001786 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001787}
1788
1789GLint State::getUnpackAlignment() const
1790{
1791 return mUnpack.alignment;
1792}
1793
Minmin Gongb8aee3b2015-01-27 14:42:36 -08001794void State::setUnpackRowLength(GLint rowLength)
1795{
1796 mUnpack.rowLength = rowLength;
Jamie Madillc67323a2017-11-02 23:11:41 -04001797 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongb8aee3b2015-01-27 14:42:36 -08001798}
1799
1800GLint State::getUnpackRowLength() const
1801{
1802 return mUnpack.rowLength;
1803}
1804
Minmin Gongadff67b2015-10-14 10:34:45 -04001805void State::setUnpackImageHeight(GLint imageHeight)
1806{
1807 mUnpack.imageHeight = imageHeight;
Jamie Madillc67323a2017-11-02 23:11:41 -04001808 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001809}
1810
1811GLint State::getUnpackImageHeight() const
1812{
1813 return mUnpack.imageHeight;
1814}
1815
1816void State::setUnpackSkipImages(GLint skipImages)
1817{
1818 mUnpack.skipImages = skipImages;
Jamie Madillc67323a2017-11-02 23:11:41 -04001819 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001820}
1821
1822GLint State::getUnpackSkipImages() const
1823{
1824 return mUnpack.skipImages;
1825}
1826
1827void State::setUnpackSkipRows(GLint skipRows)
1828{
1829 mUnpack.skipRows = skipRows;
Jamie Madillc67323a2017-11-02 23:11:41 -04001830 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001831}
1832
1833GLint State::getUnpackSkipRows() const
1834{
1835 return mUnpack.skipRows;
1836}
1837
1838void State::setUnpackSkipPixels(GLint skipPixels)
1839{
1840 mUnpack.skipPixels = skipPixels;
Jamie Madillc67323a2017-11-02 23:11:41 -04001841 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001842}
1843
1844GLint State::getUnpackSkipPixels() const
1845{
1846 return mUnpack.skipPixels;
1847}
1848
Shannon Woods53a94a82014-06-24 15:20:36 -04001849const PixelUnpackState &State::getUnpackState() const
1850{
1851 return mUnpack;
1852}
1853
Jamie Madill67102f02015-03-16 10:41:42 -04001854PixelUnpackState &State::getUnpackState()
1855{
1856 return mUnpack;
1857}
1858
Geoff Lang70d0f492015-12-10 17:45:46 -05001859const Debug &State::getDebug() const
1860{
1861 return mDebug;
1862}
1863
1864Debug &State::getDebug()
1865{
1866 return mDebug;
1867}
1868
Sami Väisänena797e062016-05-12 15:23:40 +03001869void State::setCoverageModulation(GLenum components)
1870{
1871 mCoverageModulation = components;
1872 mDirtyBits.set(DIRTY_BIT_COVERAGE_MODULATION);
1873}
1874
1875GLenum State::getCoverageModulation() const
1876{
1877 return mCoverageModulation;
1878}
1879
Sami Väisänene45e53b2016-05-25 10:36:04 +03001880void State::loadPathRenderingMatrix(GLenum matrixMode, const GLfloat *matrix)
1881{
1882 if (matrixMode == GL_PATH_MODELVIEW_CHROMIUM)
1883 {
1884 memcpy(mPathMatrixMV, matrix, 16 * sizeof(GLfloat));
jchen10bb2f2c42018-09-16 09:47:38 +08001885 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING);
Sami Väisänene45e53b2016-05-25 10:36:04 +03001886 }
1887 else if (matrixMode == GL_PATH_PROJECTION_CHROMIUM)
1888 {
1889 memcpy(mPathMatrixProj, matrix, 16 * sizeof(GLfloat));
jchen10bb2f2c42018-09-16 09:47:38 +08001890 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING);
Sami Väisänene45e53b2016-05-25 10:36:04 +03001891 }
1892 else
1893 {
1894 UNREACHABLE();
1895 }
1896}
1897
1898const GLfloat *State::getPathRenderingMatrix(GLenum which) const
1899{
1900 if (which == GL_PATH_MODELVIEW_MATRIX_CHROMIUM)
1901 {
1902 return mPathMatrixMV;
1903 }
1904 else if (which == GL_PATH_PROJECTION_MATRIX_CHROMIUM)
1905 {
1906 return mPathMatrixProj;
1907 }
1908
1909 UNREACHABLE();
1910 return nullptr;
1911}
1912
1913void State::setPathStencilFunc(GLenum func, GLint ref, GLuint mask)
1914{
1915 mPathStencilFunc = func;
1916 mPathStencilRef = ref;
1917 mPathStencilMask = mask;
jchen10bb2f2c42018-09-16 09:47:38 +08001918 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING);
Sami Väisänene45e53b2016-05-25 10:36:04 +03001919}
1920
1921GLenum State::getPathStencilFunc() const
1922{
1923 return mPathStencilFunc;
1924}
1925
1926GLint State::getPathStencilRef() const
1927{
1928 return mPathStencilRef;
1929}
1930
1931GLuint State::getPathStencilMask() const
1932{
1933 return mPathStencilMask;
1934}
1935
Geoff Lang1d2c41d2016-10-19 16:14:46 -07001936void State::setFramebufferSRGB(bool sRGB)
1937{
1938 mFramebufferSRGB = sRGB;
1939 mDirtyBits.set(DIRTY_BIT_FRAMEBUFFER_SRGB);
1940}
1941
1942bool State::getFramebufferSRGB() const
1943{
1944 return mFramebufferSRGB;
1945}
1946
jchen1082af6202018-06-22 10:59:52 +08001947void State::setMaxShaderCompilerThreads(GLuint count)
1948{
1949 mMaxShaderCompilerThreads = count;
1950}
1951
1952GLuint State::getMaxShaderCompilerThreads() const
1953{
1954 return mMaxShaderCompilerThreads;
1955}
1956
Shannon Woods53a94a82014-06-24 15:20:36 -04001957void State::getBooleanv(GLenum pname, GLboolean *params)
1958{
1959 switch (pname)
1960 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001961 case GL_SAMPLE_COVERAGE_INVERT:
1962 *params = mSampleCoverageInvert;
1963 break;
1964 case GL_DEPTH_WRITEMASK:
1965 *params = mDepthStencil.depthMask;
1966 break;
1967 case GL_COLOR_WRITEMASK:
1968 params[0] = mBlend.colorMaskRed;
1969 params[1] = mBlend.colorMaskGreen;
1970 params[2] = mBlend.colorMaskBlue;
1971 params[3] = mBlend.colorMaskAlpha;
1972 break;
1973 case GL_CULL_FACE:
1974 *params = mRasterizer.cullFace;
1975 break;
1976 case GL_POLYGON_OFFSET_FILL:
1977 *params = mRasterizer.polygonOffsetFill;
1978 break;
1979 case GL_SAMPLE_ALPHA_TO_COVERAGE:
1980 *params = mBlend.sampleAlphaToCoverage;
1981 break;
1982 case GL_SAMPLE_COVERAGE:
1983 *params = mSampleCoverage;
1984 break;
1985 case GL_SAMPLE_MASK:
1986 *params = mSampleMask;
1987 break;
1988 case GL_SCISSOR_TEST:
1989 *params = mScissorTest;
1990 break;
1991 case GL_STENCIL_TEST:
1992 *params = mDepthStencil.stencilTest;
1993 break;
1994 case GL_DEPTH_TEST:
1995 *params = mDepthStencil.depthTest;
1996 break;
1997 case GL_BLEND:
1998 *params = mBlend.blend;
1999 break;
2000 case GL_DITHER:
2001 *params = mBlend.dither;
2002 break;
2003 case GL_TRANSFORM_FEEDBACK_ACTIVE:
2004 *params = getCurrentTransformFeedback()->isActive() ? GL_TRUE : GL_FALSE;
2005 break;
2006 case GL_TRANSFORM_FEEDBACK_PAUSED:
2007 *params = getCurrentTransformFeedback()->isPaused() ? GL_TRUE : GL_FALSE;
2008 break;
2009 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
2010 *params = mPrimitiveRestart;
2011 break;
2012 case GL_RASTERIZER_DISCARD:
2013 *params = isRasterizerDiscardEnabled() ? GL_TRUE : GL_FALSE;
2014 break;
2015 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
2016 *params = mDebug.isOutputSynchronous() ? GL_TRUE : GL_FALSE;
2017 break;
2018 case GL_DEBUG_OUTPUT:
2019 *params = mDebug.isOutputEnabled() ? GL_TRUE : GL_FALSE;
2020 break;
2021 case GL_MULTISAMPLE_EXT:
2022 *params = mMultiSampling;
2023 break;
2024 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
2025 *params = mSampleAlphaToOne;
2026 break;
2027 case GL_BIND_GENERATES_RESOURCE_CHROMIUM:
2028 *params = isBindGeneratesResourceEnabled() ? GL_TRUE : GL_FALSE;
2029 break;
2030 case GL_CLIENT_ARRAYS_ANGLE:
2031 *params = areClientArraysEnabled() ? GL_TRUE : GL_FALSE;
2032 break;
2033 case GL_FRAMEBUFFER_SRGB_EXT:
2034 *params = getFramebufferSRGB() ? GL_TRUE : GL_FALSE;
2035 break;
2036 case GL_ROBUST_RESOURCE_INITIALIZATION_ANGLE:
2037 *params = mRobustResourceInit ? GL_TRUE : GL_FALSE;
2038 break;
2039 case GL_PROGRAM_CACHE_ENABLED_ANGLE:
2040 *params = mProgramBinaryCacheEnabled ? GL_TRUE : GL_FALSE;
2041 break;
Lingfeng Yangd0febe72018-05-17 22:36:52 -07002042 case GL_LIGHT_MODEL_TWO_SIDE:
2043 *params = IsLightModelTwoSided(&mGLES1State);
2044 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002045 default:
2046 UNREACHABLE();
2047 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002048 }
2049}
2050
2051void State::getFloatv(GLenum pname, GLfloat *params)
2052{
2053 // Please note: DEPTH_CLEAR_VALUE is included in our internal getFloatv implementation
2054 // because it is stored as a float, despite the fact that the GL ES 2.0 spec names
2055 // GetIntegerv as its native query function. As it would require conversion in any
2056 // case, this should make no difference to the calling application.
2057 switch (pname)
2058 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002059 case GL_LINE_WIDTH:
2060 *params = mLineWidth;
2061 break;
2062 case GL_SAMPLE_COVERAGE_VALUE:
2063 *params = mSampleCoverageValue;
2064 break;
2065 case GL_DEPTH_CLEAR_VALUE:
2066 *params = mDepthClearValue;
2067 break;
2068 case GL_POLYGON_OFFSET_FACTOR:
2069 *params = mRasterizer.polygonOffsetFactor;
2070 break;
2071 case GL_POLYGON_OFFSET_UNITS:
2072 *params = mRasterizer.polygonOffsetUnits;
2073 break;
2074 case GL_DEPTH_RANGE:
2075 params[0] = mNearZ;
2076 params[1] = mFarZ;
2077 break;
2078 case GL_COLOR_CLEAR_VALUE:
2079 params[0] = mColorClearValue.red;
2080 params[1] = mColorClearValue.green;
2081 params[2] = mColorClearValue.blue;
2082 params[3] = mColorClearValue.alpha;
2083 break;
2084 case GL_BLEND_COLOR:
2085 params[0] = mBlendColor.red;
2086 params[1] = mBlendColor.green;
2087 params[2] = mBlendColor.blue;
2088 params[3] = mBlendColor.alpha;
2089 break;
2090 case GL_MULTISAMPLE_EXT:
2091 *params = static_cast<GLfloat>(mMultiSampling);
2092 break;
2093 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
2094 *params = static_cast<GLfloat>(mSampleAlphaToOne);
2095 break;
2096 case GL_COVERAGE_MODULATION_CHROMIUM:
2097 params[0] = static_cast<GLfloat>(mCoverageModulation);
2098 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -07002099 case GL_ALPHA_TEST_REF:
2100 *params = mGLES1State.mAlphaTestRef;
2101 break;
Lingfeng Yanga43994c2018-03-29 07:21:41 -07002102 case GL_CURRENT_COLOR:
2103 {
2104 const auto &color = mGLES1State.mCurrentColor;
2105 params[0] = color.red;
2106 params[1] = color.green;
2107 params[2] = color.blue;
2108 params[3] = color.alpha;
2109 break;
2110 }
Lingfeng Yang5a7e61b2018-03-29 16:50:32 -07002111 case GL_CURRENT_NORMAL:
2112 {
2113 const auto &normal = mGLES1State.mCurrentNormal;
2114 params[0] = normal[0];
2115 params[1] = normal[1];
2116 params[2] = normal[2];
2117 break;
2118 }
Lingfeng Yang038dd532018-03-29 17:31:52 -07002119 case GL_CURRENT_TEXTURE_COORDS:
2120 {
2121 const auto &texcoord = mGLES1State.mCurrentTextureCoords[mActiveSampler];
2122 params[0] = texcoord.s;
2123 params[1] = texcoord.t;
2124 params[2] = texcoord.r;
2125 params[3] = texcoord.q;
2126 break;
2127 }
Lingfeng Yang3a41af62018-04-09 07:28:56 -07002128 case GL_MODELVIEW_MATRIX:
2129 memcpy(params, mGLES1State.mModelviewMatrices.back().data(), 16 * sizeof(GLfloat));
2130 break;
2131 case GL_PROJECTION_MATRIX:
2132 memcpy(params, mGLES1State.mProjectionMatrices.back().data(), 16 * sizeof(GLfloat));
2133 break;
2134 case GL_TEXTURE_MATRIX:
2135 memcpy(params, mGLES1State.mTextureMatrices[mActiveSampler].back().data(),
2136 16 * sizeof(GLfloat));
2137 break;
Lingfeng Yangd0febe72018-05-17 22:36:52 -07002138 case GL_LIGHT_MODEL_AMBIENT:
2139 GetLightModelParameters(&mGLES1State, pname, params);
2140 break;
Lingfeng Yang7ba3f422018-06-01 09:43:04 -07002141 case GL_FOG_MODE:
2142 case GL_FOG_DENSITY:
2143 case GL_FOG_START:
2144 case GL_FOG_END:
2145 case GL_FOG_COLOR:
2146 GetFogParameters(&mGLES1State, pname, params);
2147 break;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -07002148 case GL_POINT_SIZE:
2149 GetPointSize(&mGLES1State, params);
2150 break;
2151 case GL_POINT_SIZE_MIN:
2152 case GL_POINT_SIZE_MAX:
2153 case GL_POINT_FADE_THRESHOLD_SIZE:
2154 case GL_POINT_DISTANCE_ATTENUATION:
2155 GetPointParameter(&mGLES1State, FromGLenum<PointParameter>(pname), params);
2156 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002157 default:
2158 UNREACHABLE();
2159 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002160 }
2161}
2162
Jamie Madille98b1b52018-03-08 09:47:23 -05002163Error State::getIntegerv(const Context *context, GLenum pname, GLint *params)
Shannon Woods53a94a82014-06-24 15:20:36 -04002164{
2165 if (pname >= GL_DRAW_BUFFER0_EXT && pname <= GL_DRAW_BUFFER15_EXT)
2166 {
2167 unsigned int colorAttachment = (pname - GL_DRAW_BUFFER0_EXT);
Shannon Woods2df6a602014-09-26 16:12:07 -04002168 ASSERT(colorAttachment < mMaxDrawBuffers);
Shannon Woods53a94a82014-06-24 15:20:36 -04002169 Framebuffer *framebuffer = mDrawFramebuffer;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002170 *params = framebuffer->getDrawBufferState(colorAttachment);
Jamie Madille98b1b52018-03-08 09:47:23 -05002171 return NoError();
Shannon Woods53a94a82014-06-24 15:20:36 -04002172 }
2173
2174 // Please note: DEPTH_CLEAR_VALUE is not included in our internal getIntegerv implementation
2175 // because it is stored as a float, despite the fact that the GL ES 2.0 spec names
2176 // GetIntegerv as its native query function. As it would require conversion in any
2177 // case, this should make no difference to the calling application. You may find it in
2178 // State::getFloatv.
2179 switch (pname)
2180 {
Corentin Wallez336129f2017-10-17 15:55:40 -04002181 case GL_ARRAY_BUFFER_BINDING:
2182 *params = mBoundBuffers[BufferBinding::Array].id();
2183 break;
2184 case GL_DRAW_INDIRECT_BUFFER_BINDING:
2185 *params = mBoundBuffers[BufferBinding::DrawIndirect].id();
2186 break;
2187 case GL_ELEMENT_ARRAY_BUFFER_BINDING:
2188 *params = getVertexArray()->getElementArrayBuffer().id();
2189 break;
Jamie Madill690c8eb2018-03-12 15:20:03 -04002190 case GL_DRAW_FRAMEBUFFER_BINDING:
2191 static_assert(GL_DRAW_FRAMEBUFFER_BINDING == GL_DRAW_FRAMEBUFFER_BINDING_ANGLE,
2192 "Enum mismatch");
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002193 *params = mDrawFramebuffer->id();
2194 break;
Jamie Madill690c8eb2018-03-12 15:20:03 -04002195 case GL_READ_FRAMEBUFFER_BINDING:
2196 static_assert(GL_READ_FRAMEBUFFER_BINDING == GL_READ_FRAMEBUFFER_BINDING_ANGLE,
2197 "Enum mismatch");
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002198 *params = mReadFramebuffer->id();
2199 break;
2200 case GL_RENDERBUFFER_BINDING:
2201 *params = mRenderbuffer.id();
2202 break;
2203 case GL_VERTEX_ARRAY_BINDING:
2204 *params = mVertexArray->id();
2205 break;
2206 case GL_CURRENT_PROGRAM:
2207 *params = mProgram ? mProgram->id() : 0;
2208 break;
2209 case GL_PACK_ALIGNMENT:
2210 *params = mPack.alignment;
2211 break;
2212 case GL_PACK_REVERSE_ROW_ORDER_ANGLE:
2213 *params = mPack.reverseRowOrder;
2214 break;
2215 case GL_PACK_ROW_LENGTH:
2216 *params = mPack.rowLength;
2217 break;
2218 case GL_PACK_SKIP_ROWS:
2219 *params = mPack.skipRows;
2220 break;
2221 case GL_PACK_SKIP_PIXELS:
2222 *params = mPack.skipPixels;
2223 break;
2224 case GL_UNPACK_ALIGNMENT:
2225 *params = mUnpack.alignment;
2226 break;
2227 case GL_UNPACK_ROW_LENGTH:
2228 *params = mUnpack.rowLength;
2229 break;
2230 case GL_UNPACK_IMAGE_HEIGHT:
2231 *params = mUnpack.imageHeight;
2232 break;
2233 case GL_UNPACK_SKIP_IMAGES:
2234 *params = mUnpack.skipImages;
2235 break;
2236 case GL_UNPACK_SKIP_ROWS:
2237 *params = mUnpack.skipRows;
2238 break;
2239 case GL_UNPACK_SKIP_PIXELS:
2240 *params = mUnpack.skipPixels;
2241 break;
2242 case GL_GENERATE_MIPMAP_HINT:
2243 *params = mGenerateMipmapHint;
2244 break;
2245 case GL_FRAGMENT_SHADER_DERIVATIVE_HINT_OES:
2246 *params = mFragmentShaderDerivativeHint;
2247 break;
2248 case GL_ACTIVE_TEXTURE:
2249 *params = (static_cast<GLint>(mActiveSampler) + GL_TEXTURE0);
2250 break;
2251 case GL_STENCIL_FUNC:
2252 *params = mDepthStencil.stencilFunc;
2253 break;
2254 case GL_STENCIL_REF:
2255 *params = mStencilRef;
2256 break;
2257 case GL_STENCIL_VALUE_MASK:
2258 *params = CastMaskValue(context, mDepthStencil.stencilMask);
2259 break;
2260 case GL_STENCIL_BACK_FUNC:
2261 *params = mDepthStencil.stencilBackFunc;
2262 break;
2263 case GL_STENCIL_BACK_REF:
2264 *params = mStencilBackRef;
2265 break;
2266 case GL_STENCIL_BACK_VALUE_MASK:
2267 *params = CastMaskValue(context, mDepthStencil.stencilBackMask);
2268 break;
2269 case GL_STENCIL_FAIL:
2270 *params = mDepthStencil.stencilFail;
2271 break;
2272 case GL_STENCIL_PASS_DEPTH_FAIL:
2273 *params = mDepthStencil.stencilPassDepthFail;
2274 break;
2275 case GL_STENCIL_PASS_DEPTH_PASS:
2276 *params = mDepthStencil.stencilPassDepthPass;
2277 break;
2278 case GL_STENCIL_BACK_FAIL:
2279 *params = mDepthStencil.stencilBackFail;
2280 break;
2281 case GL_STENCIL_BACK_PASS_DEPTH_FAIL:
2282 *params = mDepthStencil.stencilBackPassDepthFail;
2283 break;
2284 case GL_STENCIL_BACK_PASS_DEPTH_PASS:
2285 *params = mDepthStencil.stencilBackPassDepthPass;
2286 break;
2287 case GL_DEPTH_FUNC:
2288 *params = mDepthStencil.depthFunc;
2289 break;
2290 case GL_BLEND_SRC_RGB:
2291 *params = mBlend.sourceBlendRGB;
2292 break;
2293 case GL_BLEND_SRC_ALPHA:
2294 *params = mBlend.sourceBlendAlpha;
2295 break;
2296 case GL_BLEND_DST_RGB:
2297 *params = mBlend.destBlendRGB;
2298 break;
2299 case GL_BLEND_DST_ALPHA:
2300 *params = mBlend.destBlendAlpha;
2301 break;
2302 case GL_BLEND_EQUATION_RGB:
2303 *params = mBlend.blendEquationRGB;
2304 break;
2305 case GL_BLEND_EQUATION_ALPHA:
2306 *params = mBlend.blendEquationAlpha;
2307 break;
2308 case GL_STENCIL_WRITEMASK:
2309 *params = CastMaskValue(context, mDepthStencil.stencilWritemask);
2310 break;
2311 case GL_STENCIL_BACK_WRITEMASK:
2312 *params = CastMaskValue(context, mDepthStencil.stencilBackWritemask);
2313 break;
2314 case GL_STENCIL_CLEAR_VALUE:
2315 *params = mStencilClearValue;
2316 break;
2317 case GL_IMPLEMENTATION_COLOR_READ_TYPE:
Jamie Madill690c8eb2018-03-12 15:20:03 -04002318 ANGLE_TRY(mReadFramebuffer->getImplementationColorReadType(
2319 context, reinterpret_cast<GLenum *>(params)));
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002320 break;
2321 case GL_IMPLEMENTATION_COLOR_READ_FORMAT:
Jamie Madill690c8eb2018-03-12 15:20:03 -04002322 ANGLE_TRY(mReadFramebuffer->getImplementationColorReadFormat(
2323 context, reinterpret_cast<GLenum *>(params)));
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002324 break;
2325 case GL_SAMPLE_BUFFERS:
2326 case GL_SAMPLES:
Shannon Woods53a94a82014-06-24 15:20:36 -04002327 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002328 Framebuffer *framebuffer = mDrawFramebuffer;
Jamie Madill427064d2018-04-13 16:20:34 -04002329 if (framebuffer->isComplete(context))
Shannon Woods53a94a82014-06-24 15:20:36 -04002330 {
Jamie Madill427064d2018-04-13 16:20:34 -04002331 GLint samples = framebuffer->getSamples(context);
Shannon Woods53a94a82014-06-24 15:20:36 -04002332 switch (pname)
2333 {
Jamie Madilla0016b72017-07-14 14:30:46 -04002334 case GL_SAMPLE_BUFFERS:
Jamie Madille98b1b52018-03-08 09:47:23 -05002335 if (samples != 0)
Jamie Madilla0016b72017-07-14 14:30:46 -04002336 {
2337 *params = 1;
2338 }
2339 else
2340 {
2341 *params = 0;
2342 }
2343 break;
2344 case GL_SAMPLES:
Jamie Madille98b1b52018-03-08 09:47:23 -05002345 *params = samples;
Jamie Madilla0016b72017-07-14 14:30:46 -04002346 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002347 }
2348 }
2349 else
2350 {
2351 *params = 0;
2352 }
2353 }
2354 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002355 case GL_VIEWPORT:
2356 params[0] = mViewport.x;
2357 params[1] = mViewport.y;
2358 params[2] = mViewport.width;
2359 params[3] = mViewport.height;
2360 break;
2361 case GL_SCISSOR_BOX:
2362 params[0] = mScissor.x;
2363 params[1] = mScissor.y;
2364 params[2] = mScissor.width;
2365 params[3] = mScissor.height;
2366 break;
2367 case GL_CULL_FACE_MODE:
2368 *params = ToGLenum(mRasterizer.cullMode);
2369 break;
2370 case GL_FRONT_FACE:
2371 *params = mRasterizer.frontFace;
2372 break;
2373 case GL_RED_BITS:
2374 case GL_GREEN_BITS:
2375 case GL_BLUE_BITS:
2376 case GL_ALPHA_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002377 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002378 Framebuffer *framebuffer = getDrawFramebuffer();
2379 const FramebufferAttachment *colorbuffer = framebuffer->getFirstColorbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002380
2381 if (colorbuffer)
2382 {
2383 switch (pname)
2384 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002385 case GL_RED_BITS:
2386 *params = colorbuffer->getRedSize();
2387 break;
2388 case GL_GREEN_BITS:
2389 *params = colorbuffer->getGreenSize();
2390 break;
2391 case GL_BLUE_BITS:
2392 *params = colorbuffer->getBlueSize();
2393 break;
2394 case GL_ALPHA_BITS:
2395 *params = colorbuffer->getAlphaSize();
2396 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002397 }
2398 }
2399 else
2400 {
2401 *params = 0;
2402 }
2403 }
2404 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002405 case GL_DEPTH_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002406 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002407 const Framebuffer *framebuffer = getDrawFramebuffer();
2408 const FramebufferAttachment *depthbuffer = framebuffer->getDepthbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002409
2410 if (depthbuffer)
2411 {
2412 *params = depthbuffer->getDepthSize();
2413 }
2414 else
2415 {
2416 *params = 0;
2417 }
2418 }
2419 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002420 case GL_STENCIL_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002421 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002422 const Framebuffer *framebuffer = getDrawFramebuffer();
2423 const FramebufferAttachment *stencilbuffer = framebuffer->getStencilbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002424
2425 if (stencilbuffer)
2426 {
2427 *params = stencilbuffer->getStencilSize();
2428 }
2429 else
2430 {
2431 *params = 0;
2432 }
2433 }
2434 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002435 case GL_TEXTURE_BINDING_2D:
2436 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2437 *params =
2438 getSamplerTextureId(static_cast<unsigned int>(mActiveSampler), TextureType::_2D);
2439 break;
2440 case GL_TEXTURE_BINDING_RECTANGLE_ANGLE:
2441 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2442 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2443 TextureType::Rectangle);
2444 break;
2445 case GL_TEXTURE_BINDING_CUBE_MAP:
2446 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2447 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2448 TextureType::CubeMap);
2449 break;
2450 case GL_TEXTURE_BINDING_3D:
2451 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2452 *params =
2453 getSamplerTextureId(static_cast<unsigned int>(mActiveSampler), TextureType::_3D);
2454 break;
2455 case GL_TEXTURE_BINDING_2D_ARRAY:
2456 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2457 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2458 TextureType::_2DArray);
2459 break;
2460 case GL_TEXTURE_BINDING_2D_MULTISAMPLE:
2461 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2462 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2463 TextureType::_2DMultisample);
2464 break;
Olli Etuahodff32a02018-08-28 14:35:50 +03002465 case GL_TEXTURE_BINDING_2D_MULTISAMPLE_ARRAY:
2466 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2467 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2468 TextureType::_2DMultisampleArray);
2469 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002470 case GL_TEXTURE_BINDING_EXTERNAL_OES:
2471 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2472 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2473 TextureType::External);
2474 break;
2475 case GL_UNIFORM_BUFFER_BINDING:
2476 *params = mBoundBuffers[BufferBinding::Uniform].id();
2477 break;
2478 case GL_TRANSFORM_FEEDBACK_BINDING:
2479 *params = mTransformFeedback.id();
2480 break;
2481 case GL_TRANSFORM_FEEDBACK_BUFFER_BINDING:
2482 *params = mBoundBuffers[BufferBinding::TransformFeedback].id();
2483 break;
2484 case GL_COPY_READ_BUFFER_BINDING:
2485 *params = mBoundBuffers[BufferBinding::CopyRead].id();
2486 break;
2487 case GL_COPY_WRITE_BUFFER_BINDING:
2488 *params = mBoundBuffers[BufferBinding::CopyWrite].id();
2489 break;
2490 case GL_PIXEL_PACK_BUFFER_BINDING:
2491 *params = mBoundBuffers[BufferBinding::PixelPack].id();
2492 break;
2493 case GL_PIXEL_UNPACK_BUFFER_BINDING:
2494 *params = mBoundBuffers[BufferBinding::PixelUnpack].id();
2495 break;
2496 case GL_READ_BUFFER:
2497 *params = mReadFramebuffer->getReadBufferState();
2498 break;
2499 case GL_SAMPLER_BINDING:
2500 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2501 *params = getSamplerId(static_cast<GLuint>(mActiveSampler));
2502 break;
2503 case GL_DEBUG_LOGGED_MESSAGES:
2504 *params = static_cast<GLint>(mDebug.getMessageCount());
2505 break;
2506 case GL_DEBUG_NEXT_LOGGED_MESSAGE_LENGTH:
2507 *params = static_cast<GLint>(mDebug.getNextMessageLength());
2508 break;
2509 case GL_DEBUG_GROUP_STACK_DEPTH:
2510 *params = static_cast<GLint>(mDebug.getGroupStackDepth());
2511 break;
2512 case GL_MULTISAMPLE_EXT:
2513 *params = static_cast<GLint>(mMultiSampling);
2514 break;
2515 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
2516 *params = static_cast<GLint>(mSampleAlphaToOne);
2517 break;
2518 case GL_COVERAGE_MODULATION_CHROMIUM:
2519 *params = static_cast<GLint>(mCoverageModulation);
2520 break;
2521 case GL_ATOMIC_COUNTER_BUFFER_BINDING:
2522 *params = mBoundBuffers[BufferBinding::AtomicCounter].id();
2523 break;
2524 case GL_SHADER_STORAGE_BUFFER_BINDING:
2525 *params = mBoundBuffers[BufferBinding::ShaderStorage].id();
2526 break;
2527 case GL_DISPATCH_INDIRECT_BUFFER_BINDING:
2528 *params = mBoundBuffers[BufferBinding::DispatchIndirect].id();
2529 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -07002530 case GL_ALPHA_TEST_FUNC:
2531 *params = ToGLenum(mGLES1State.mAlphaTestFunc);
2532 break;
Lingfeng Yang96310cd2018-03-28 11:56:28 -07002533 case GL_CLIENT_ACTIVE_TEXTURE:
2534 *params = mGLES1State.mClientActiveTexture + GL_TEXTURE0;
2535 break;
Lingfeng Yangd2488ab2018-04-04 09:25:48 -07002536 case GL_MATRIX_MODE:
2537 *params = ToGLenum(mGLES1State.mMatrixMode);
2538 break;
Lingfeng Yanga0cfa872018-05-30 21:12:17 -07002539 case GL_SHADE_MODEL:
2540 *params = ToGLenum(mGLES1State.mShadeModel);
2541 break;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -07002542 case GL_MODELVIEW_STACK_DEPTH:
2543 case GL_PROJECTION_STACK_DEPTH:
2544 case GL_TEXTURE_STACK_DEPTH:
2545 *params = mGLES1State.getCurrentMatrixStackDepth(pname);
2546 break;
2547 case GL_LOGIC_OP_MODE:
2548 *params = ToGLenum(mGLES1State.mLogicOp);
2549 break;
2550 case GL_BLEND_SRC:
2551 *params = mBlend.sourceBlendRGB;
2552 break;
2553 case GL_BLEND_DST:
2554 *params = mBlend.destBlendRGB;
2555 break;
2556 case GL_PERSPECTIVE_CORRECTION_HINT:
2557 case GL_POINT_SMOOTH_HINT:
2558 case GL_LINE_SMOOTH_HINT:
2559 case GL_FOG_HINT:
2560 *params = mGLES1State.getHint(pname);
2561 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002562 default:
2563 UNREACHABLE();
2564 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002565 }
Jamie Madille98b1b52018-03-08 09:47:23 -05002566
2567 return NoError();
Shannon Woods53a94a82014-06-24 15:20:36 -04002568}
2569
Lingfeng Yangabb09f12018-04-16 10:43:53 -07002570void State::getPointerv(const Context *context, GLenum pname, void **params) const
Geoff Lang70d0f492015-12-10 17:45:46 -05002571{
2572 switch (pname)
2573 {
2574 case GL_DEBUG_CALLBACK_FUNCTION:
2575 *params = reinterpret_cast<void *>(mDebug.getCallback());
2576 break;
2577 case GL_DEBUG_CALLBACK_USER_PARAM:
2578 *params = const_cast<void *>(mDebug.getUserParam());
2579 break;
Lingfeng Yangabb09f12018-04-16 10:43:53 -07002580 case GL_VERTEX_ARRAY_POINTER:
2581 case GL_NORMAL_ARRAY_POINTER:
2582 case GL_COLOR_ARRAY_POINTER:
2583 case GL_TEXTURE_COORD_ARRAY_POINTER:
2584 case GL_POINT_SIZE_ARRAY_POINTER_OES:
2585 QueryVertexAttribPointerv(getVertexArray()->getVertexAttribute(
2586 context->vertexArrayIndex(ParamToVertexArrayType(pname))),
2587 GL_VERTEX_ATTRIB_ARRAY_POINTER, params);
2588 return;
Geoff Lang70d0f492015-12-10 17:45:46 -05002589 default:
2590 UNREACHABLE();
2591 break;
2592 }
2593}
2594
Martin Radev66fb8202016-07-28 11:45:20 +03002595void State::getIntegeri_v(GLenum target, GLuint index, GLint *data)
Shannon Woods53a94a82014-06-24 15:20:36 -04002596{
2597 switch (target)
2598 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002599 case GL_TRANSFORM_FEEDBACK_BUFFER_BINDING:
2600 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2601 *data = mTransformFeedback->getIndexedBuffer(index).id();
2602 break;
2603 case GL_UNIFORM_BUFFER_BINDING:
2604 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2605 *data = mUniformBuffers[index].id();
2606 break;
2607 case GL_ATOMIC_COUNTER_BUFFER_BINDING:
2608 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2609 *data = mAtomicCounterBuffers[index].id();
2610 break;
2611 case GL_SHADER_STORAGE_BUFFER_BINDING:
2612 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2613 *data = mShaderStorageBuffers[index].id();
2614 break;
2615 case GL_VERTEX_BINDING_BUFFER:
2616 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2617 *data = mVertexArray->getVertexBinding(index).getBuffer().id();
2618 break;
2619 case GL_VERTEX_BINDING_DIVISOR:
2620 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2621 *data = mVertexArray->getVertexBinding(index).getDivisor();
2622 break;
2623 case GL_VERTEX_BINDING_OFFSET:
2624 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2625 *data = static_cast<GLuint>(mVertexArray->getVertexBinding(index).getOffset());
2626 break;
2627 case GL_VERTEX_BINDING_STRIDE:
2628 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2629 *data = mVertexArray->getVertexBinding(index).getStride();
2630 break;
2631 case GL_SAMPLE_MASK_VALUE:
2632 ASSERT(static_cast<size_t>(index) < mSampleMaskValues.size());
2633 *data = mSampleMaskValues[index];
2634 break;
2635 case GL_IMAGE_BINDING_NAME:
2636 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2637 *data = mImageUnits[index].texture.id();
2638 break;
2639 case GL_IMAGE_BINDING_LEVEL:
2640 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2641 *data = mImageUnits[index].level;
2642 break;
2643 case GL_IMAGE_BINDING_LAYER:
2644 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2645 *data = mImageUnits[index].layer;
2646 break;
2647 case GL_IMAGE_BINDING_ACCESS:
2648 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2649 *data = mImageUnits[index].access;
2650 break;
2651 case GL_IMAGE_BINDING_FORMAT:
2652 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2653 *data = mImageUnits[index].format;
2654 break;
2655 default:
2656 UNREACHABLE();
2657 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002658 }
Shannon Woods53a94a82014-06-24 15:20:36 -04002659}
2660
Martin Radev66fb8202016-07-28 11:45:20 +03002661void State::getInteger64i_v(GLenum target, GLuint index, GLint64 *data)
Shannon Woods53a94a82014-06-24 15:20:36 -04002662{
2663 switch (target)
2664 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002665 case GL_TRANSFORM_FEEDBACK_BUFFER_START:
2666 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2667 *data = mTransformFeedback->getIndexedBuffer(index).getOffset();
2668 break;
2669 case GL_TRANSFORM_FEEDBACK_BUFFER_SIZE:
2670 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2671 *data = mTransformFeedback->getIndexedBuffer(index).getSize();
2672 break;
2673 case GL_UNIFORM_BUFFER_START:
2674 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2675 *data = mUniformBuffers[index].getOffset();
2676 break;
2677 case GL_UNIFORM_BUFFER_SIZE:
2678 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2679 *data = mUniformBuffers[index].getSize();
2680 break;
2681 case GL_ATOMIC_COUNTER_BUFFER_START:
2682 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2683 *data = mAtomicCounterBuffers[index].getOffset();
2684 break;
2685 case GL_ATOMIC_COUNTER_BUFFER_SIZE:
2686 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2687 *data = mAtomicCounterBuffers[index].getSize();
2688 break;
2689 case GL_SHADER_STORAGE_BUFFER_START:
2690 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2691 *data = mShaderStorageBuffers[index].getOffset();
2692 break;
2693 case GL_SHADER_STORAGE_BUFFER_SIZE:
2694 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2695 *data = mShaderStorageBuffers[index].getSize();
2696 break;
2697 default:
2698 UNREACHABLE();
2699 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002700 }
Martin Radev66fb8202016-07-28 11:45:20 +03002701}
Shannon Woods53a94a82014-06-24 15:20:36 -04002702
Martin Radev66fb8202016-07-28 11:45:20 +03002703void State::getBooleani_v(GLenum target, GLuint index, GLboolean *data)
2704{
Xinghua Cao9c8e1a32017-12-06 17:59:58 +08002705 switch (target)
2706 {
2707 case GL_IMAGE_BINDING_LAYERED:
2708 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2709 *data = mImageUnits[index].layered;
2710 break;
2711 default:
2712 UNREACHABLE();
2713 break;
2714 }
Shannon Woods53a94a82014-06-24 15:20:36 -04002715}
2716
Jamie Madill6f755b22018-10-09 12:48:54 -04002717angle::Result State::syncDirtyObjects(const Context *context, const DirtyObjects &bitset)
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002718{
Jiajia Qin5ae6ee42018-03-06 17:39:42 +08002719 const DirtyObjects &dirtyObjects = mDirtyObjects & bitset;
2720 for (auto dirtyObject : dirtyObjects)
Jamie Madillc9d442d2016-01-20 11:17:24 -05002721 {
2722 switch (dirtyObject)
2723 {
2724 case DIRTY_OBJECT_READ_FRAMEBUFFER:
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002725 ASSERT(mReadFramebuffer);
Jamie Madill19fa1c62018-03-08 09:47:21 -05002726 ANGLE_TRY(mReadFramebuffer->syncState(context));
Jamie Madillc9d442d2016-01-20 11:17:24 -05002727 break;
2728 case DIRTY_OBJECT_DRAW_FRAMEBUFFER:
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002729 ASSERT(mDrawFramebuffer);
Jamie Madill19fa1c62018-03-08 09:47:21 -05002730 ANGLE_TRY(mDrawFramebuffer->syncState(context));
Jamie Madillc9d442d2016-01-20 11:17:24 -05002731 break;
2732 case DIRTY_OBJECT_VERTEX_ARRAY:
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002733 ASSERT(mVertexArray);
Frank Henigman0af5b862018-03-27 20:19:33 -04002734 ANGLE_TRY(mVertexArray->syncState(context));
Jamie Madillc9d442d2016-01-20 11:17:24 -05002735 break;
Jamie Madille25b8002018-09-20 13:39:49 -04002736 case DIRTY_OBJECT_SAMPLERS:
2737 syncSamplers(context);
2738 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002739 case DIRTY_OBJECT_PROGRAM_TEXTURES:
Luc Ferron4bba74f2018-04-19 14:40:45 -04002740 ANGLE_TRY(syncProgramTextures(context));
Jamie Madill81c2e252017-09-09 23:32:46 -04002741 break;
Jamie Madill70aeda42018-08-20 12:17:40 -04002742 case DIRTY_OBJECT_PROGRAM:
2743 ANGLE_TRY(mProgram->syncState(context));
2744 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002745
Jamie Madillc9d442d2016-01-20 11:17:24 -05002746 default:
2747 UNREACHABLE();
2748 break;
2749 }
2750 }
2751
Jiajia Qin5ae6ee42018-03-06 17:39:42 +08002752 mDirtyObjects &= ~dirtyObjects;
Jamie Madill6f755b22018-10-09 12:48:54 -04002753 return angle::Result::Continue();
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002754}
2755
Jamie Madille25b8002018-09-20 13:39:49 -04002756void State::syncSamplers(const Context *context)
2757{
2758 if (mDirtySamplers.none())
2759 return;
2760
2761 // This could be optimized by tracking which samplers are dirty.
2762 for (size_t samplerIndex : mDirtySamplers)
2763 {
2764 BindingPointer<Sampler> &sampler = mSamplers[samplerIndex];
2765 if (sampler.get())
2766 {
2767 sampler->syncState(context);
2768 }
2769 }
2770
2771 mDirtySamplers.reset();
2772}
2773
Jamie Madill6f755b22018-10-09 12:48:54 -04002774angle::Result State::syncProgramTextures(const Context *context)
Jamie Madill81c2e252017-09-09 23:32:46 -04002775{
Jamie Madill81c2e252017-09-09 23:32:46 -04002776 // TODO(jmadill): Fine-grained updates.
2777 if (!mProgram)
2778 {
Jamie Madill6f755b22018-10-09 12:48:54 -04002779 return angle::Result::Continue();
Jamie Madill81c2e252017-09-09 23:32:46 -04002780 }
2781
2782 ASSERT(mDirtyObjects[DIRTY_OBJECT_PROGRAM_TEXTURES]);
2783 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
2784
Jamie Madill0f80ed82017-09-19 00:24:56 -04002785 ActiveTextureMask newActiveTextures;
2786
Geoff Lange51ba632017-11-21 11:45:25 -05002787 // Initialize to the 'Initialized' state and set to 'MayNeedInit' if any texture is not
2788 // initialized.
2789 mCachedTexturesInitState = InitState::Initialized;
Qin Jiajia47f6dd02018-08-10 13:36:32 +08002790 mCachedImageTexturesInitState = InitState::Initialized;
Geoff Lange51ba632017-11-21 11:45:25 -05002791
Jamie Madill7e4eff12018-08-08 15:49:26 -04002792 const ActiveTextureMask &activeTextures = mProgram->getActiveSamplersMask();
2793 const ActiveTextureArray<TextureType> &textureTypes = mProgram->getActiveSamplerTypes();
2794
2795 for (size_t textureUnitIndex : activeTextures)
Jamie Madill81c2e252017-09-09 23:32:46 -04002796 {
Jamie Madill7e4eff12018-08-08 15:49:26 -04002797 TextureType textureType = textureTypes[textureUnitIndex];
Jamie Madill81c2e252017-09-09 23:32:46 -04002798
jchen1090f466a2018-08-13 15:05:25 +08002799 Texture *texture =
2800 getSamplerTexture(static_cast<unsigned int>(textureUnitIndex), textureType);
Jamie Madill7e4eff12018-08-08 15:49:26 -04002801 ASSERT(static_cast<size_t>(textureUnitIndex) < newActiveTextures.size());
2802
2803 ASSERT(texture);
2804
Jamie Madill7e4eff12018-08-08 15:49:26 -04002805 newActiveTextures.set(textureUnitIndex);
Jamie Madille3bb6b72018-10-03 17:51:15 -04002806 ANGLE_TRY(updateActiveTexture(context, textureUnitIndex, texture));
Jamie Madill81c2e252017-09-09 23:32:46 -04002807 }
Jamie Madill0f80ed82017-09-19 00:24:56 -04002808
2809 // Unset now missing textures.
Jamie Madill7e4eff12018-08-08 15:49:26 -04002810 ActiveTextureMask negativeMask = activeTextures & ~newActiveTextures;
Jamie Madill0f80ed82017-09-19 00:24:56 -04002811 if (negativeMask.any())
2812 {
Jamie Madille3bb6b72018-10-03 17:51:15 -04002813 unsetActiveTextures(negativeMask);
Jamie Madill0f80ed82017-09-19 00:24:56 -04002814 }
Luc Ferron4bba74f2018-04-19 14:40:45 -04002815
Qin Jiajia47f6dd02018-08-10 13:36:32 +08002816 for (size_t imageUnitIndex : mProgram->getActiveImagesMask())
2817 {
2818 Texture *texture = mImageUnits[imageUnitIndex].texture.get();
2819 if (!texture)
2820 {
2821 continue;
2822 }
Jamie Madillf668a4b2018-09-23 17:01:20 -04002823 if (texture->hasAnyDirtyBit())
2824 {
2825 ANGLE_TRY(texture->syncState(context));
2826 }
Qin Jiajia47f6dd02018-08-10 13:36:32 +08002827 if (texture->initState() == InitState::MayNeedInit)
2828 {
2829 mCachedImageTexturesInitState = InitState::MayNeedInit;
2830 }
2831 }
2832
Jamie Madill6f755b22018-10-09 12:48:54 -04002833 return angle::Result::Continue();
Jamie Madill81c2e252017-09-09 23:32:46 -04002834}
2835
Jamie Madill6f755b22018-10-09 12:48:54 -04002836angle::Result State::syncDirtyObject(const Context *context, GLenum target)
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002837{
2838 DirtyObjects localSet;
2839
2840 switch (target)
2841 {
2842 case GL_READ_FRAMEBUFFER:
2843 localSet.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2844 break;
2845 case GL_DRAW_FRAMEBUFFER:
2846 localSet.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2847 break;
2848 case GL_FRAMEBUFFER:
2849 localSet.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2850 localSet.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2851 break;
2852 case GL_VERTEX_ARRAY:
2853 localSet.set(DIRTY_OBJECT_VERTEX_ARRAY);
2854 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002855 case GL_TEXTURE:
Jamie Madille25b8002018-09-20 13:39:49 -04002856 localSet.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
2857 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002858 case GL_SAMPLER:
Jamie Madill70aeda42018-08-20 12:17:40 -04002859 localSet.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Jamie Madille25b8002018-09-20 13:39:49 -04002860 localSet.set(DIRTY_OBJECT_SAMPLERS);
Jamie Madill70aeda42018-08-20 12:17:40 -04002861 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002862 case GL_PROGRAM:
2863 localSet.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Jamie Madill70aeda42018-08-20 12:17:40 -04002864 localSet.set(DIRTY_OBJECT_PROGRAM);
Jamie Madill81c2e252017-09-09 23:32:46 -04002865 break;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002866 }
2867
Jamie Madillbc918e72018-03-08 09:47:21 -05002868 return syncDirtyObjects(context, localSet);
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002869}
2870
2871void State::setObjectDirty(GLenum target)
2872{
2873 switch (target)
2874 {
2875 case GL_READ_FRAMEBUFFER:
2876 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2877 break;
2878 case GL_DRAW_FRAMEBUFFER:
2879 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2880 break;
2881 case GL_FRAMEBUFFER:
2882 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2883 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2884 break;
2885 case GL_VERTEX_ARRAY:
2886 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
2887 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002888 case GL_TEXTURE:
Jamie Madill70aeda42018-08-20 12:17:40 -04002889 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
2890 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
2891 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002892 case GL_PROGRAM:
2893 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Jamie Madill70aeda42018-08-20 12:17:40 -04002894 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM);
Jamie Madill81c2e252017-09-09 23:32:46 -04002895 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
2896 break;
Jamie Madilla779b612017-07-24 11:46:05 -04002897 }
2898}
2899
Jamie Madill6f755b22018-10-09 12:48:54 -04002900angle::Result State::onProgramExecutableChange(const Context *context, Program *program)
Jamie Madilla779b612017-07-24 11:46:05 -04002901{
2902 // OpenGL Spec:
2903 // "If LinkProgram or ProgramBinary successfully re-links a program object
2904 // that was already in use as a result of a previous call to UseProgram, then the
2905 // generated executable code will be installed as part of the current rendering state."
Jamie Madilldf836ff2018-10-01 10:36:24 -04002906 ASSERT(program->isLinked());
2907
2908 mDirtyBits.set(DIRTY_BIT_PROGRAM_EXECUTABLE);
Jamie Madill956ab4d2018-10-10 16:13:03 -04002909
2910 if (program->hasAnyDirtyBit())
2911 {
2912 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM);
2913 }
Jamie Madille3bb6b72018-10-03 17:51:15 -04002914
2915 // Set any bound textures.
2916 const ActiveTextureTypeArray &textureTypes = program->getActiveSamplerTypes();
2917 for (size_t textureIndex : program->getActiveSamplersMask())
2918 {
2919 TextureType type = textureTypes[textureIndex];
2920
2921 // This can happen if there is a conflicting texture type.
2922 if (type == TextureType::InvalidEnum)
2923 continue;
2924
2925 Texture *texture = mSamplerTextures[type][textureIndex].get();
2926 ANGLE_TRY(updateActiveTexture(context, textureIndex, texture));
2927 }
2928
2929 for (size_t imageUnitIndex : program->getActiveImagesMask())
2930 {
2931 Texture *image = mImageUnits[imageUnitIndex].texture.get();
2932 if (!image)
2933 continue;
2934
2935 if (image->hasAnyDirtyBit())
2936 {
2937 ANGLE_TRY(image->syncState(context));
2938 }
2939
2940 if (image->initState() == InitState::MayNeedInit)
2941 {
2942 mCachedImageTexturesInitState = InitState::MayNeedInit;
2943 }
2944 }
2945
Jamie Madill6f755b22018-10-09 12:48:54 -04002946 return angle::Result::Continue();
Shannon Woods53a94a82014-06-24 15:20:36 -04002947}
Jamie Madillc9d442d2016-01-20 11:17:24 -05002948
Jamie Madille25b8002018-09-20 13:39:49 -04002949void State::setSamplerDirty(size_t samplerIndex)
2950{
2951 mDirtyObjects.set(DIRTY_OBJECT_SAMPLERS);
2952 mDirtySamplers.set(samplerIndex);
2953}
2954
Xinghua Cao65ec0b22017-03-28 16:10:52 +08002955void State::setImageUnit(const Context *context,
Will Harris63aa0e52018-09-05 16:15:46 -07002956 size_t unit,
Xinghua Cao65ec0b22017-03-28 16:10:52 +08002957 Texture *texture,
2958 GLint level,
2959 GLboolean layered,
2960 GLint layer,
2961 GLenum access,
2962 GLenum format)
2963{
2964 mImageUnits[unit].texture.set(context, texture);
2965 mImageUnits[unit].level = level;
2966 mImageUnits[unit].layered = layered;
2967 mImageUnits[unit].layer = layer;
2968 mImageUnits[unit].access = access;
2969 mImageUnits[unit].format = format;
jchen1099118c12018-09-10 16:28:51 +08002970 mDirtyBits.set(DIRTY_BIT_IMAGE_BINDINGS);
Xinghua Cao65ec0b22017-03-28 16:10:52 +08002971}
2972
Will Harris63aa0e52018-09-05 16:15:46 -07002973const ImageUnit &State::getImageUnit(size_t unit) const
Xinghua Cao65ec0b22017-03-28 16:10:52 +08002974{
2975 return mImageUnits[unit];
2976}
2977
Jamie Madill81c2e252017-09-09 23:32:46 -04002978// Handle a dirty texture event.
Jamie Madill6c43a012018-08-08 15:49:27 -04002979void State::onActiveTextureStateChange(size_t textureIndex)
Jamie Madill81c2e252017-09-09 23:32:46 -04002980{
2981 // Conservatively assume all textures are dirty.
2982 // TODO(jmadill): More fine-grained update.
2983 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Geoff Lange51ba632017-11-21 11:45:25 -05002984
Jamie Madill6c43a012018-08-08 15:49:27 -04002985 if (!mActiveTexturesCache[textureIndex] ||
2986 mActiveTexturesCache[textureIndex]->initState() == InitState::MayNeedInit)
Geoff Lange51ba632017-11-21 11:45:25 -05002987 {
2988 mCachedTexturesInitState = InitState::MayNeedInit;
2989 }
Jamie Madill81c2e252017-09-09 23:32:46 -04002990}
2991
Jamie Madill6d32cef2018-08-14 02:34:28 -04002992void State::onUniformBufferStateChange(size_t uniformBufferIndex)
2993{
2994 // This could be represented by a different dirty bit. Using the same one keeps it simple.
2995 mDirtyBits.set(DIRTY_BIT_UNIFORM_BUFFER_BINDINGS);
2996}
2997
Jamie Madill6f755b22018-10-09 12:48:54 -04002998angle::Result State::clearUnclearedActiveTextures(const Context *context)
Jamie Madill05b35b22017-10-03 09:01:44 -04002999{
Jamie Madilla59fc192017-11-02 12:57:58 -04003000 ASSERT(mRobustResourceInit);
Geoff Lang9bf86f02018-07-26 11:46:34 -04003001 ASSERT(!mDirtyObjects[DIRTY_OBJECT_PROGRAM_TEXTURES]);
Geoff Langd4fff502017-09-22 11:28:28 -04003002
Jamie Madill7e4eff12018-08-08 15:49:26 -04003003 if (!mProgram)
Jamie Madill6f755b22018-10-09 12:48:54 -04003004 return angle::Result::Continue();
Jamie Madill7e4eff12018-08-08 15:49:26 -04003005
Qin Jiajia47f6dd02018-08-10 13:36:32 +08003006 if (mCachedTexturesInitState != InitState::Initialized)
Jamie Madill05b35b22017-10-03 09:01:44 -04003007 {
Qin Jiajia47f6dd02018-08-10 13:36:32 +08003008 for (size_t textureUnitIndex : mProgram->getActiveSamplersMask())
Jamie Madill05b35b22017-10-03 09:01:44 -04003009 {
Qin Jiajia47f6dd02018-08-10 13:36:32 +08003010 Texture *texture = mActiveTexturesCache[textureUnitIndex];
3011 if (texture)
3012 {
3013 ANGLE_TRY(texture->ensureInitialized(context));
3014 }
Jamie Madill05b35b22017-10-03 09:01:44 -04003015 }
Qin Jiajia47f6dd02018-08-10 13:36:32 +08003016 mCachedTexturesInitState = InitState::Initialized;
Jamie Madill05b35b22017-10-03 09:01:44 -04003017 }
Qin Jiajia47f6dd02018-08-10 13:36:32 +08003018 if (mCachedImageTexturesInitState != InitState::Initialized)
3019 {
3020 for (size_t imageUnitIndex : mProgram->getActiveImagesMask())
3021 {
3022 Texture *texture = mImageUnits[imageUnitIndex].texture.get();
3023 if (texture)
3024 {
3025 ANGLE_TRY(texture->ensureInitialized(context));
3026 }
3027 }
3028 mCachedImageTexturesInitState = InitState::Initialized;
3029 }
Jamie Madill6f755b22018-10-09 12:48:54 -04003030 return angle::Result::Continue();
Jamie Madill05b35b22017-10-03 09:01:44 -04003031}
3032
Jamie Madillc67323a2017-11-02 23:11:41 -04003033AttributesMask State::getAndResetDirtyCurrentValues() const
3034{
3035 AttributesMask retVal = mDirtyCurrentValues;
3036 mDirtyCurrentValues.reset();
3037 return retVal;
3038}
3039
James Darpiniane8a93c62018-01-04 18:02:24 -08003040bool State::isCurrentTransformFeedback(const TransformFeedback *tf) const
3041{
3042 return tf == mTransformFeedback.get();
3043}
Jamie Madillc9d442d2016-01-20 11:17:24 -05003044} // namespace gl