blob: afc49ace9a6924558a8d59eb717fa0569ae2f9d2 [file] [log] [blame]
Shannon Woods53a94a82014-06-24 15:20:36 -04001//
2// Copyright (c) 2014 The ANGLE Project Authors. All rights reserved.
3// Use of this source code is governed by a BSD-style license that can be
4// found in the LICENSE file.
5//
6
7// State.cpp: Implements the State class, encapsulating raw GL state.
8
Geoff Lang2b5420c2014-11-19 14:20:15 -05009#include "libANGLE/State.h"
Shannon Woods53a94a82014-06-24 15:20:36 -040010
Sami Väisänene45e53b2016-05-25 10:36:04 +030011#include <string.h>
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -070012#include <limits>
Sami Väisänene45e53b2016-05-25 10:36:04 +030013
Jamie Madill20e005b2017-04-07 14:19:22 -040014#include "common/bitset_utils.h"
Sami Väisänene45e53b2016-05-25 10:36:04 +030015#include "common/mathutil.h"
jchen10a99ed552017-09-22 08:10:32 +080016#include "common/matrix_utils.h"
Geoff Lang2b5420c2014-11-19 14:20:15 -050017#include "libANGLE/Caps.h"
jchen10a99ed552017-09-22 08:10:32 +080018#include "libANGLE/Context.h"
Geoff Lang70d0f492015-12-10 17:45:46 -050019#include "libANGLE/Debug.h"
Geoff Lang2b5420c2014-11-19 14:20:15 -050020#include "libANGLE/Framebuffer.h"
21#include "libANGLE/FramebufferAttachment.h"
22#include "libANGLE/Query.h"
23#include "libANGLE/VertexArray.h"
24#include "libANGLE/formatutils.h"
jchen10a99ed552017-09-22 08:10:32 +080025#include "libANGLE/queryconversions.h"
Lingfeng Yangabb09f12018-04-16 10:43:53 -070026#include "libANGLE/queryutils.h"
Geoff Lang4751aab2017-10-30 15:14:52 -040027#include "libANGLE/renderer/ContextImpl.h"
Shannon Woods53a94a82014-06-24 15:20:36 -040028
Corentin Wallezad3ae902018-03-09 13:40:42 -050029namespace gl
30{
31
Olli Etuahobbf1c102016-06-28 13:31:33 +030032namespace
33{
34
Corentin Wallezad3ae902018-03-09 13:40:42 -050035bool GetAlternativeQueryType(QueryType type, QueryType *alternativeType)
Olli Etuahobbf1c102016-06-28 13:31:33 +030036{
Corentin Wallezad3ae902018-03-09 13:40:42 -050037 switch (type)
38 {
39 case QueryType::AnySamples:
40 *alternativeType = QueryType::AnySamplesConservative;
41 return true;
42 case QueryType::AnySamplesConservative:
43 *alternativeType = QueryType::AnySamples;
44 return true;
45 default:
46 return false;
47 }
Olli Etuahobbf1c102016-06-28 13:31:33 +030048}
49
50} // anonymous namepace
51
Jamie Madillbf5177d2018-08-21 12:58:20 -040052template <typename BindingT, typename... ArgsT>
53void UpdateNonTFBufferBinding(const Context *context, BindingT *binding, ArgsT... args)
James Darpiniane8a93c62018-01-04 18:02:24 -080054{
55 if (binding->get())
Jamie Madillbf5177d2018-08-21 12:58:20 -040056 (*binding)->onNonTFBindingChanged(context, -1);
57 binding->set(context, args...);
James Darpiniane8a93c62018-01-04 18:02:24 -080058 if (binding->get())
Jamie Madillbf5177d2018-08-21 12:58:20 -040059 (*binding)->onNonTFBindingChanged(context, 1);
60}
61
62template <typename BindingT, typename... ArgsT>
63void UpdateTFBufferBinding(const Context *context, BindingT *binding, bool indexed, ArgsT... args)
64{
65 if (binding->get())
66 (*binding)->onTFBindingChanged(context, false, indexed);
67 binding->set(context, args...);
68 if (binding->get())
69 (*binding)->onTFBindingChanged(context, true, indexed);
James Darpiniane8a93c62018-01-04 18:02:24 -080070}
71
72void UpdateBufferBinding(const Context *context,
Jamie Madillbf5177d2018-08-21 12:58:20 -040073 BindingPointer<Buffer> *binding,
James Darpiniane8a93c62018-01-04 18:02:24 -080074 Buffer *buffer,
Jamie Madillbf5177d2018-08-21 12:58:20 -040075 BufferBinding target)
James Darpiniane8a93c62018-01-04 18:02:24 -080076{
Jamie Madillbf5177d2018-08-21 12:58:20 -040077 if (target == BufferBinding::TransformFeedback)
78 {
79 UpdateTFBufferBinding(context, binding, false, buffer);
80 }
81 else
82 {
83 UpdateNonTFBufferBinding(context, binding, buffer);
84 }
85}
86
87void UpdateIndexedBufferBinding(const Context *context,
88 OffsetBindingPointer<Buffer> *binding,
89 Buffer *buffer,
90 BufferBinding target,
91 GLintptr offset,
92 GLsizeiptr size)
93{
94 if (target == BufferBinding::TransformFeedback)
95 {
96 UpdateTFBufferBinding(context, binding, true, buffer, offset, size);
97 }
98 else
99 {
100 UpdateNonTFBufferBinding(context, binding, buffer, offset, size);
101 }
James Darpiniane8a93c62018-01-04 18:02:24 -0800102}
103
Geoff Lang4fb8a8b2018-06-01 16:47:57 -0400104State::State(bool debug,
105 bool bindGeneratesResource,
106 bool clientArraysEnabled,
107 bool robustResourceInit,
108 bool programBinaryCacheEnabled)
Jamie Madille79b1e12015-11-04 16:36:37 -0500109 : mMaxDrawBuffers(0),
110 mMaxCombinedTextureImageUnits(0),
111 mDepthClearValue(0),
112 mStencilClearValue(0),
113 mScissorTest(false),
114 mSampleCoverage(false),
115 mSampleCoverageValue(0),
116 mSampleCoverageInvert(false),
Jiawei Shaodb342272017-09-27 10:21:45 +0800117 mSampleMask(false),
118 mMaxSampleMaskWords(0),
Jamie Madille79b1e12015-11-04 16:36:37 -0500119 mStencilRef(0),
120 mStencilBackRef(0),
121 mLineWidth(0),
122 mGenerateMipmapHint(GL_NONE),
123 mFragmentShaderDerivativeHint(GL_NONE),
Geoff Lang4fb8a8b2018-06-01 16:47:57 -0400124 mBindGeneratesResource(bindGeneratesResource),
125 mClientArraysEnabled(clientArraysEnabled),
Jamie Madille79b1e12015-11-04 16:36:37 -0500126 mNearZ(0),
127 mFarZ(0),
128 mReadFramebuffer(nullptr),
129 mDrawFramebuffer(nullptr),
130 mProgram(nullptr),
131 mVertexArray(nullptr),
132 mActiveSampler(0),
Jamie Madill4787d702018-08-08 15:49:26 -0400133 mActiveTexturesCache{},
134 mCachedTexturesInitState(InitState::MayNeedInit),
Sami Väisänen74c23472016-05-09 17:30:30 +0300135 mPrimitiveRestart(false),
Geoff Lang4fb8a8b2018-06-01 16:47:57 -0400136 mDebug(debug),
Sami Väisänen74c23472016-05-09 17:30:30 +0300137 mMultiSampling(false),
Geoff Lang1d2c41d2016-10-19 16:14:46 -0700138 mSampleAlphaToOne(false),
Jamie Madille08a1d32017-03-07 17:24:06 -0500139 mFramebufferSRGB(true),
Geoff Lang4fb8a8b2018-06-01 16:47:57 -0400140 mRobustResourceInit(robustResourceInit),
jchen1082af6202018-06-22 10:59:52 +0800141 mProgramBinaryCacheEnabled(programBinaryCacheEnabled),
142 mMaxShaderCompilerThreads(std::numeric_limits<GLuint>::max())
Shannon Woods53a94a82014-06-24 15:20:36 -0400143{
Geoff Lang76b10c92014-09-05 16:28:14 -0400144}
145
Lingfeng Yang13b708f2018-03-21 12:14:10 -0700146State::~State()
147{
148}
Geoff Lang76b10c92014-09-05 16:28:14 -0400149
Jamie Madill6c43a012018-08-08 15:49:27 -0400150void State::initialize(Context *context)
Geoff Lang76b10c92014-09-05 16:28:14 -0400151{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700152 const Caps &caps = context->getCaps();
153 const Extensions &extensions = context->getExtensions();
Geoff Lang4751aab2017-10-30 15:14:52 -0400154 const Extensions &nativeExtensions = context->getImplementation()->getNativeExtensions();
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700155 const Version &clientVersion = context->getClientVersion();
Jamie Madill4928b7c2017-06-20 12:57:39 -0400156
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700157 mMaxDrawBuffers = caps.maxDrawBuffers;
Shannon Woods2df6a602014-09-26 16:12:07 -0400158 mMaxCombinedTextureImageUnits = caps.maxCombinedTextureImageUnits;
Shannon Woods53a94a82014-06-24 15:20:36 -0400159
Jamie Madillf75ab352015-03-16 10:46:52 -0400160 setColorClearValue(0.0f, 0.0f, 0.0f, 0.0f);
Shannon Woods53a94a82014-06-24 15:20:36 -0400161
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700162 mDepthClearValue = 1.0f;
Shannon Woods53a94a82014-06-24 15:20:36 -0400163 mStencilClearValue = 0;
164
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700165 mScissorTest = false;
166 mScissor.x = 0;
167 mScissor.y = 0;
168 mScissor.width = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400169 mScissor.height = 0;
170
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700171 mBlendColor.red = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400172 mBlendColor.green = 0;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700173 mBlendColor.blue = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400174 mBlendColor.alpha = 0;
175
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700176 mStencilRef = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400177 mStencilBackRef = 0;
178
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700179 mSampleCoverage = false;
180 mSampleCoverageValue = 1.0f;
Shannon Woods53a94a82014-06-24 15:20:36 -0400181 mSampleCoverageInvert = false;
Jiawei Shaodb342272017-09-27 10:21:45 +0800182
183 mMaxSampleMaskWords = caps.maxSampleMaskWords;
184 mSampleMask = false;
185 mSampleMaskValues.fill(~GLbitfield(0));
186
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700187 mGenerateMipmapHint = GL_DONT_CARE;
Shannon Woods53a94a82014-06-24 15:20:36 -0400188 mFragmentShaderDerivativeHint = GL_DONT_CARE;
189
190 mLineWidth = 1.0f;
191
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700192 mViewport.x = 0;
193 mViewport.y = 0;
194 mViewport.width = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400195 mViewport.height = 0;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700196 mNearZ = 0.0f;
197 mFarZ = 1.0f;
Shannon Woods53a94a82014-06-24 15:20:36 -0400198
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700199 mBlend.colorMaskRed = true;
Shannon Woods53a94a82014-06-24 15:20:36 -0400200 mBlend.colorMaskGreen = true;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700201 mBlend.colorMaskBlue = true;
Shannon Woods53a94a82014-06-24 15:20:36 -0400202 mBlend.colorMaskAlpha = true;
203
Geoff Lang76b10c92014-09-05 16:28:14 -0400204 mActiveSampler = 0;
205
Shannon Woods23e05002014-09-22 19:07:27 -0400206 mVertexAttribCurrentValues.resize(caps.maxVertexAttributes);
Shannon Woods53a94a82014-06-24 15:20:36 -0400207
Brandon Jonesc405ae72017-12-06 14:15:03 -0800208 // Set all indexes in state attributes type mask to float (default)
209 for (int i = 0; i < MAX_VERTEX_ATTRIBS; i++)
210 {
211 mCurrentValuesTypeMask.setIndex(GL_FLOAT, i);
212 }
213
Geoff Lang4dc3af02016-11-18 14:09:27 -0500214 mUniformBuffers.resize(caps.maxUniformBufferBindings);
Shannon Woodsf3acaf92014-09-23 18:07:11 -0400215
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800216 mSamplerTextures[TextureType::_2D].resize(caps.maxCombinedTextureImageUnits);
217 mSamplerTextures[TextureType::CubeMap].resize(caps.maxCombinedTextureImageUnits);
Geoff Langeb66a6e2016-10-31 13:06:12 -0400218 if (clientVersion >= Version(3, 0))
Shannon Woods53a94a82014-06-24 15:20:36 -0400219 {
Geoff Lang76b10c92014-09-05 16:28:14 -0400220 // TODO: These could also be enabled via extension
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800221 mSamplerTextures[TextureType::_2DArray].resize(caps.maxCombinedTextureImageUnits);
222 mSamplerTextures[TextureType::_3D].resize(caps.maxCombinedTextureImageUnits);
Shannon Woods53a94a82014-06-24 15:20:36 -0400223 }
Geoff Lang3b573612016-10-31 14:08:10 -0400224 if (clientVersion >= Version(3, 1))
225 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800226 mSamplerTextures[TextureType::_2DMultisample].resize(caps.maxCombinedTextureImageUnits);
Jiajia Qin6eafb042016-12-27 17:04:07 +0800227
228 mAtomicCounterBuffers.resize(caps.maxAtomicCounterBufferBindings);
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800229 mShaderStorageBuffers.resize(caps.maxShaderStorageBufferBindings);
Xinghua Cao65ec0b22017-03-28 16:10:52 +0800230 mImageUnits.resize(caps.maxImageUnits);
Geoff Lang3b573612016-10-31 14:08:10 -0400231 }
Geoff Lang4751aab2017-10-30 15:14:52 -0400232 if (nativeExtensions.textureRectangle)
Corentin Wallez13c0dd42017-07-04 18:27:01 -0400233 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800234 mSamplerTextures[TextureType::Rectangle].resize(caps.maxCombinedTextureImageUnits);
Corentin Wallez13c0dd42017-07-04 18:27:01 -0400235 }
Geoff Lang4751aab2017-10-30 15:14:52 -0400236 if (nativeExtensions.eglImageExternal || nativeExtensions.eglStreamConsumerExternal)
Ian Ewellbda75592016-04-18 17:25:54 -0400237 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800238 mSamplerTextures[TextureType::External].resize(caps.maxCombinedTextureImageUnits);
Ian Ewellbda75592016-04-18 17:25:54 -0400239 }
Jamie Madill81c2e252017-09-09 23:32:46 -0400240 mCompleteTextureBindings.reserve(caps.maxCombinedTextureImageUnits);
Geoff Lange51ba632017-11-21 11:45:25 -0500241 mCachedTexturesInitState = InitState::MayNeedInit;
Jamie Madill81c2e252017-09-09 23:32:46 -0400242 for (uint32_t textureIndex = 0; textureIndex < caps.maxCombinedTextureImageUnits;
243 ++textureIndex)
244 {
Jamie Madill6c43a012018-08-08 15:49:27 -0400245 mCompleteTextureBindings.emplace_back(context, textureIndex);
Jamie Madill81c2e252017-09-09 23:32:46 -0400246 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400247
Geoff Lang76b10c92014-09-05 16:28:14 -0400248 mSamplers.resize(caps.maxCombinedTextureImageUnits);
Shannon Woods53a94a82014-06-24 15:20:36 -0400249
Corentin Wallezad3ae902018-03-09 13:40:42 -0500250 for (QueryType type : angle::AllEnums<QueryType>())
251 {
252 mActiveQueries[type].set(context, nullptr);
253 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400254
Ian Ewell3ffd78b2016-01-22 16:09:42 -0500255 mProgram = nullptr;
Shannon Woods53a94a82014-06-24 15:20:36 -0400256
Ian Ewell3ffd78b2016-01-22 16:09:42 -0500257 mReadFramebuffer = nullptr;
258 mDrawFramebuffer = nullptr;
Jamie Madillb4b53c52015-02-03 15:22:48 -0500259
260 mPrimitiveRestart = false;
Geoff Lang70d0f492015-12-10 17:45:46 -0500261
Geoff Lang70d0f492015-12-10 17:45:46 -0500262 mDebug.setMaxLoggedMessages(extensions.maxDebugLoggedMessages);
Sami Väisänen74c23472016-05-09 17:30:30 +0300263
Geoff Lang488130e2017-09-27 13:53:11 -0400264 mMultiSampling = true;
265 mSampleAlphaToOne = false;
Sami Väisänena797e062016-05-12 15:23:40 +0300266
267 mCoverageModulation = GL_NONE;
Sami Väisänene45e53b2016-05-25 10:36:04 +0300268
269 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixProj);
270 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixMV);
271 mPathStencilFunc = GL_ALWAYS;
272 mPathStencilRef = 0;
273 mPathStencilMask = std::numeric_limits<GLuint>::max();
Jamie Madille08a1d32017-03-07 17:24:06 -0500274
Lingfeng Yangdbb9c532018-02-25 19:58:24 -0800275 // GLES1 emulation: Initialize state for GLES1 if version
276 // applies
277 if (clientVersion < Version(2, 0))
278 {
Lingfeng Yange547aac2018-04-05 09:39:20 -0700279 mGLES1State.initialize(context, this);
Lingfeng Yangdbb9c532018-02-25 19:58:24 -0800280 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400281}
282
Jamie Madill6c1f6712017-02-14 19:08:04 -0500283void State::reset(const Context *context)
Shannon Woods53a94a82014-06-24 15:20:36 -0400284{
Jamie Madill8693bdb2017-09-02 15:32:14 -0400285 for (auto &bindingVec : mSamplerTextures)
Shannon Woods53a94a82014-06-24 15:20:36 -0400286 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800287 for (size_t textureIdx = 0; textureIdx < bindingVec.size(); textureIdx++)
Shannon Woods53a94a82014-06-24 15:20:36 -0400288 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800289 bindingVec[textureIdx].set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400290 }
291 }
Geoff Lang76b10c92014-09-05 16:28:14 -0400292 for (size_t samplerIdx = 0; samplerIdx < mSamplers.size(); samplerIdx++)
293 {
Jamie Madill4928b7c2017-06-20 12:57:39 -0400294 mSamplers[samplerIdx].set(context, nullptr);
Geoff Lang76b10c92014-09-05 16:28:14 -0400295 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400296
Xinghua Cao65ec0b22017-03-28 16:10:52 +0800297 for (auto &imageUnit : mImageUnits)
298 {
299 imageUnit.texture.set(context, nullptr);
300 imageUnit.level = 0;
301 imageUnit.layered = false;
302 imageUnit.layer = 0;
303 imageUnit.access = GL_READ_ONLY;
304 imageUnit.format = GL_R32UI;
305 }
306
Jamie Madill4928b7c2017-06-20 12:57:39 -0400307 mRenderbuffer.set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400308
Corentin Wallez336129f2017-10-17 15:55:40 -0400309 for (auto type : angle::AllEnums<BufferBinding>())
310 {
Jamie Madillbf5177d2018-08-21 12:58:20 -0400311 UpdateBufferBinding(context, &mBoundBuffers[type], nullptr, type);
Corentin Wallez336129f2017-10-17 15:55:40 -0400312 }
313
Geoff Lang7dd2e102014-11-10 15:19:26 -0500314 if (mProgram)
315 {
Jamie Madill6c1f6712017-02-14 19:08:04 -0500316 mProgram->release(context);
Geoff Lang7dd2e102014-11-10 15:19:26 -0500317 }
Yunchao Hed7297bf2017-04-19 15:27:10 +0800318 mProgram = nullptr;
Geoff Lang7dd2e102014-11-10 15:19:26 -0500319
Yunchao Hea336b902017-08-02 16:05:21 +0800320 mProgramPipeline.set(context, nullptr);
321
James Darpiniane8a93c62018-01-04 18:02:24 -0800322 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -0400323 mTransformFeedback->onBindingChanged(context, false);
Jamie Madill4928b7c2017-06-20 12:57:39 -0400324 mTransformFeedback.set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400325
Corentin Wallezad3ae902018-03-09 13:40:42 -0500326 for (QueryType type : angle::AllEnums<QueryType>())
Shannon Woods53a94a82014-06-24 15:20:36 -0400327 {
Corentin Wallezad3ae902018-03-09 13:40:42 -0500328 mActiveQueries[type].set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400329 }
330
Corentin Wallez336129f2017-10-17 15:55:40 -0400331 for (auto &buf : mUniformBuffers)
Shannon Woods53a94a82014-06-24 15:20:36 -0400332 {
Jamie Madillbf5177d2018-08-21 12:58:20 -0400333 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::Uniform, 0, 0);
Shannon Woods53a94a82014-06-24 15:20:36 -0400334 }
335
Jiajia Qin6eafb042016-12-27 17:04:07 +0800336 for (auto &buf : mAtomicCounterBuffers)
337 {
Jamie Madillbf5177d2018-08-21 12:58:20 -0400338 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::AtomicCounter, 0, 0);
Jiajia Qin6eafb042016-12-27 17:04:07 +0800339 }
340
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800341 for (auto &buf : mShaderStorageBuffers)
342 {
Jamie Madillbf5177d2018-08-21 12:58:20 -0400343 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::ShaderStorage, 0, 0);
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800344 }
345
Sami Väisänene45e53b2016-05-25 10:36:04 +0300346 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixProj);
347 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixMV);
348 mPathStencilFunc = GL_ALWAYS;
349 mPathStencilRef = 0;
350 mPathStencilMask = std::numeric_limits<GLuint>::max();
351
Jamie Madill1b94d432015-08-07 13:23:23 -0400352 // TODO(jmadill): Is this necessary?
353 setAllDirtyBits();
Shannon Woods53a94a82014-06-24 15:20:36 -0400354}
355
356const RasterizerState &State::getRasterizerState() const
357{
358 return mRasterizer;
359}
360
361const BlendState &State::getBlendState() const
362{
363 return mBlend;
364}
365
366const DepthStencilState &State::getDepthStencilState() const
367{
368 return mDepthStencil;
369}
370
Jamie Madillf75ab352015-03-16 10:46:52 -0400371void State::setColorClearValue(float red, float green, float blue, float alpha)
Shannon Woods53a94a82014-06-24 15:20:36 -0400372{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700373 mColorClearValue.red = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400374 mColorClearValue.green = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700375 mColorClearValue.blue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400376 mColorClearValue.alpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400377 mDirtyBits.set(DIRTY_BIT_CLEAR_COLOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400378}
379
Jamie Madillf75ab352015-03-16 10:46:52 -0400380void State::setDepthClearValue(float depth)
Shannon Woods53a94a82014-06-24 15:20:36 -0400381{
382 mDepthClearValue = depth;
Jamie Madill1b94d432015-08-07 13:23:23 -0400383 mDirtyBits.set(DIRTY_BIT_CLEAR_DEPTH);
Shannon Woods53a94a82014-06-24 15:20:36 -0400384}
385
Jamie Madillf75ab352015-03-16 10:46:52 -0400386void State::setStencilClearValue(int stencil)
Shannon Woods53a94a82014-06-24 15:20:36 -0400387{
388 mStencilClearValue = stencil;
Jamie Madill1b94d432015-08-07 13:23:23 -0400389 mDirtyBits.set(DIRTY_BIT_CLEAR_STENCIL);
Shannon Woods53a94a82014-06-24 15:20:36 -0400390}
391
Shannon Woods53a94a82014-06-24 15:20:36 -0400392void State::setColorMask(bool red, bool green, bool blue, bool alpha)
393{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700394 mBlend.colorMaskRed = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400395 mBlend.colorMaskGreen = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700396 mBlend.colorMaskBlue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400397 mBlend.colorMaskAlpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400398 mDirtyBits.set(DIRTY_BIT_COLOR_MASK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400399}
400
401void State::setDepthMask(bool mask)
402{
403 mDepthStencil.depthMask = mask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400404 mDirtyBits.set(DIRTY_BIT_DEPTH_MASK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400405}
406
407bool State::isRasterizerDiscardEnabled() const
408{
409 return mRasterizer.rasterizerDiscard;
410}
411
412void State::setRasterizerDiscard(bool enabled)
413{
414 mRasterizer.rasterizerDiscard = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400415 mDirtyBits.set(DIRTY_BIT_RASTERIZER_DISCARD_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400416}
417
418bool State::isCullFaceEnabled() const
419{
420 return mRasterizer.cullFace;
421}
422
423void State::setCullFace(bool enabled)
424{
425 mRasterizer.cullFace = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400426 mDirtyBits.set(DIRTY_BIT_CULL_FACE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400427}
428
Corentin Wallez2e568cf2017-09-18 17:05:22 -0400429void State::setCullMode(CullFaceMode mode)
Shannon Woods53a94a82014-06-24 15:20:36 -0400430{
431 mRasterizer.cullMode = mode;
Jamie Madill1b94d432015-08-07 13:23:23 -0400432 mDirtyBits.set(DIRTY_BIT_CULL_FACE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400433}
434
435void State::setFrontFace(GLenum front)
436{
437 mRasterizer.frontFace = front;
Jamie Madill1b94d432015-08-07 13:23:23 -0400438 mDirtyBits.set(DIRTY_BIT_FRONT_FACE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400439}
440
441bool State::isDepthTestEnabled() const
442{
443 return mDepthStencil.depthTest;
444}
445
446void State::setDepthTest(bool enabled)
447{
448 mDepthStencil.depthTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400449 mDirtyBits.set(DIRTY_BIT_DEPTH_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400450}
451
452void State::setDepthFunc(GLenum depthFunc)
453{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700454 mDepthStencil.depthFunc = depthFunc;
455 mDirtyBits.set(DIRTY_BIT_DEPTH_FUNC);
Shannon Woods53a94a82014-06-24 15:20:36 -0400456}
457
458void State::setDepthRange(float zNear, float zFar)
459{
460 mNearZ = zNear;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700461 mFarZ = zFar;
Jamie Madill1b94d432015-08-07 13:23:23 -0400462 mDirtyBits.set(DIRTY_BIT_DEPTH_RANGE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400463}
464
Geoff Langd42f5b82015-04-16 14:03:29 -0400465float State::getNearPlane() const
Shannon Woods53a94a82014-06-24 15:20:36 -0400466{
Geoff Langd42f5b82015-04-16 14:03:29 -0400467 return mNearZ;
468}
469
470float State::getFarPlane() const
471{
472 return mFarZ;
Shannon Woods53a94a82014-06-24 15:20:36 -0400473}
474
475bool State::isBlendEnabled() const
476{
477 return mBlend.blend;
478}
479
480void State::setBlend(bool enabled)
481{
482 mBlend.blend = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400483 mDirtyBits.set(DIRTY_BIT_BLEND_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400484}
485
486void State::setBlendFactors(GLenum sourceRGB, GLenum destRGB, GLenum sourceAlpha, GLenum destAlpha)
487{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700488 mBlend.sourceBlendRGB = sourceRGB;
489 mBlend.destBlendRGB = destRGB;
Shannon Woods53a94a82014-06-24 15:20:36 -0400490 mBlend.sourceBlendAlpha = sourceAlpha;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700491 mBlend.destBlendAlpha = destAlpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400492 mDirtyBits.set(DIRTY_BIT_BLEND_FUNCS);
Shannon Woods53a94a82014-06-24 15:20:36 -0400493}
494
495void State::setBlendColor(float red, float green, float blue, float alpha)
496{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700497 mBlendColor.red = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400498 mBlendColor.green = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700499 mBlendColor.blue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400500 mBlendColor.alpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400501 mDirtyBits.set(DIRTY_BIT_BLEND_COLOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400502}
503
504void State::setBlendEquation(GLenum rgbEquation, GLenum alphaEquation)
505{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700506 mBlend.blendEquationRGB = rgbEquation;
Shannon Woods53a94a82014-06-24 15:20:36 -0400507 mBlend.blendEquationAlpha = alphaEquation;
Jamie Madill1b94d432015-08-07 13:23:23 -0400508 mDirtyBits.set(DIRTY_BIT_BLEND_EQUATIONS);
Shannon Woods53a94a82014-06-24 15:20:36 -0400509}
510
511const ColorF &State::getBlendColor() const
512{
513 return mBlendColor;
514}
515
516bool State::isStencilTestEnabled() const
517{
518 return mDepthStencil.stencilTest;
519}
520
521void State::setStencilTest(bool enabled)
522{
523 mDepthStencil.stencilTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400524 mDirtyBits.set(DIRTY_BIT_STENCIL_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400525}
526
527void State::setStencilParams(GLenum stencilFunc, GLint stencilRef, GLuint stencilMask)
528{
529 mDepthStencil.stencilFunc = stencilFunc;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700530 mStencilRef = (stencilRef > 0) ? stencilRef : 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400531 mDepthStencil.stencilMask = stencilMask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400532 mDirtyBits.set(DIRTY_BIT_STENCIL_FUNCS_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400533}
534
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700535void State::setStencilBackParams(GLenum stencilBackFunc,
536 GLint stencilBackRef,
537 GLuint stencilBackMask)
Shannon Woods53a94a82014-06-24 15:20:36 -0400538{
539 mDepthStencil.stencilBackFunc = stencilBackFunc;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700540 mStencilBackRef = (stencilBackRef > 0) ? stencilBackRef : 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400541 mDepthStencil.stencilBackMask = stencilBackMask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400542 mDirtyBits.set(DIRTY_BIT_STENCIL_FUNCS_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400543}
544
545void State::setStencilWritemask(GLuint stencilWritemask)
546{
547 mDepthStencil.stencilWritemask = stencilWritemask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400548 mDirtyBits.set(DIRTY_BIT_STENCIL_WRITEMASK_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400549}
550
551void State::setStencilBackWritemask(GLuint stencilBackWritemask)
552{
553 mDepthStencil.stencilBackWritemask = stencilBackWritemask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400554 mDirtyBits.set(DIRTY_BIT_STENCIL_WRITEMASK_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400555}
556
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700557void State::setStencilOperations(GLenum stencilFail,
558 GLenum stencilPassDepthFail,
559 GLenum stencilPassDepthPass)
Shannon Woods53a94a82014-06-24 15:20:36 -0400560{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700561 mDepthStencil.stencilFail = stencilFail;
Shannon Woods53a94a82014-06-24 15:20:36 -0400562 mDepthStencil.stencilPassDepthFail = stencilPassDepthFail;
563 mDepthStencil.stencilPassDepthPass = stencilPassDepthPass;
Jamie Madill1b94d432015-08-07 13:23:23 -0400564 mDirtyBits.set(DIRTY_BIT_STENCIL_OPS_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400565}
566
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700567void State::setStencilBackOperations(GLenum stencilBackFail,
568 GLenum stencilBackPassDepthFail,
569 GLenum stencilBackPassDepthPass)
Shannon Woods53a94a82014-06-24 15:20:36 -0400570{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700571 mDepthStencil.stencilBackFail = stencilBackFail;
Shannon Woods53a94a82014-06-24 15:20:36 -0400572 mDepthStencil.stencilBackPassDepthFail = stencilBackPassDepthFail;
573 mDepthStencil.stencilBackPassDepthPass = stencilBackPassDepthPass;
Jamie Madill1b94d432015-08-07 13:23:23 -0400574 mDirtyBits.set(DIRTY_BIT_STENCIL_OPS_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400575}
576
577GLint State::getStencilRef() const
578{
579 return mStencilRef;
580}
581
582GLint State::getStencilBackRef() const
583{
584 return mStencilBackRef;
585}
586
587bool State::isPolygonOffsetFillEnabled() const
588{
589 return mRasterizer.polygonOffsetFill;
590}
591
592void State::setPolygonOffsetFill(bool enabled)
593{
Jamie Madill1b94d432015-08-07 13:23:23 -0400594 mRasterizer.polygonOffsetFill = enabled;
595 mDirtyBits.set(DIRTY_BIT_POLYGON_OFFSET_FILL_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400596}
597
598void State::setPolygonOffsetParams(GLfloat factor, GLfloat units)
599{
600 // An application can pass NaN values here, so handle this gracefully
601 mRasterizer.polygonOffsetFactor = factor != factor ? 0.0f : factor;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700602 mRasterizer.polygonOffsetUnits = units != units ? 0.0f : units;
Jamie Madill1b94d432015-08-07 13:23:23 -0400603 mDirtyBits.set(DIRTY_BIT_POLYGON_OFFSET);
Shannon Woods53a94a82014-06-24 15:20:36 -0400604}
605
606bool State::isSampleAlphaToCoverageEnabled() const
607{
608 return mBlend.sampleAlphaToCoverage;
609}
610
611void State::setSampleAlphaToCoverage(bool enabled)
612{
613 mBlend.sampleAlphaToCoverage = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400614 mDirtyBits.set(DIRTY_BIT_SAMPLE_ALPHA_TO_COVERAGE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400615}
616
617bool State::isSampleCoverageEnabled() const
618{
619 return mSampleCoverage;
620}
621
622void State::setSampleCoverage(bool enabled)
623{
624 mSampleCoverage = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400625 mDirtyBits.set(DIRTY_BIT_SAMPLE_COVERAGE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400626}
627
628void State::setSampleCoverageParams(GLclampf value, bool invert)
629{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700630 mSampleCoverageValue = value;
Shannon Woods53a94a82014-06-24 15:20:36 -0400631 mSampleCoverageInvert = invert;
Jamie Madill1b94d432015-08-07 13:23:23 -0400632 mDirtyBits.set(DIRTY_BIT_SAMPLE_COVERAGE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400633}
634
Geoff Lang0fbb6002015-04-16 11:11:53 -0400635GLclampf State::getSampleCoverageValue() const
Shannon Woods53a94a82014-06-24 15:20:36 -0400636{
Geoff Lang0fbb6002015-04-16 11:11:53 -0400637 return mSampleCoverageValue;
638}
Shannon Woods53a94a82014-06-24 15:20:36 -0400639
Geoff Lang0fbb6002015-04-16 11:11:53 -0400640bool State::getSampleCoverageInvert() const
641{
642 return mSampleCoverageInvert;
Shannon Woods53a94a82014-06-24 15:20:36 -0400643}
644
Jiawei Shaodb342272017-09-27 10:21:45 +0800645bool State::isSampleMaskEnabled() const
646{
647 return mSampleMask;
648}
649
650void State::setSampleMaskEnabled(bool enabled)
651{
652 mSampleMask = enabled;
653 mDirtyBits.set(DIRTY_BIT_SAMPLE_MASK_ENABLED);
654}
655
656void State::setSampleMaskParams(GLuint maskNumber, GLbitfield mask)
657{
658 ASSERT(maskNumber < mMaxSampleMaskWords);
659 mSampleMaskValues[maskNumber] = mask;
Jamie Madillc67323a2017-11-02 23:11:41 -0400660 // TODO(jmadill): Use a child dirty bit if we ever use more than two words.
661 mDirtyBits.set(DIRTY_BIT_SAMPLE_MASK);
Jiawei Shaodb342272017-09-27 10:21:45 +0800662}
663
664GLbitfield State::getSampleMaskWord(GLuint maskNumber) const
665{
666 ASSERT(maskNumber < mMaxSampleMaskWords);
667 return mSampleMaskValues[maskNumber];
668}
669
670GLuint State::getMaxSampleMaskWords() const
671{
672 return mMaxSampleMaskWords;
673}
674
Sami Väisänen74c23472016-05-09 17:30:30 +0300675void State::setSampleAlphaToOne(bool enabled)
676{
677 mSampleAlphaToOne = enabled;
678 mDirtyBits.set(DIRTY_BIT_SAMPLE_ALPHA_TO_ONE);
679}
680
681bool State::isSampleAlphaToOneEnabled() const
682{
683 return mSampleAlphaToOne;
684}
685
686void State::setMultisampling(bool enabled)
687{
688 mMultiSampling = enabled;
689 mDirtyBits.set(DIRTY_BIT_MULTISAMPLING);
690}
691
692bool State::isMultisamplingEnabled() const
693{
694 return mMultiSampling;
695}
696
Shannon Woods53a94a82014-06-24 15:20:36 -0400697bool State::isScissorTestEnabled() const
698{
699 return mScissorTest;
700}
701
702void State::setScissorTest(bool enabled)
703{
704 mScissorTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400705 mDirtyBits.set(DIRTY_BIT_SCISSOR_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400706}
707
708void State::setScissorParams(GLint x, GLint y, GLsizei width, GLsizei height)
709{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700710 mScissor.x = x;
711 mScissor.y = y;
712 mScissor.width = width;
Shannon Woods53a94a82014-06-24 15:20:36 -0400713 mScissor.height = height;
Jamie Madill1b94d432015-08-07 13:23:23 -0400714 mDirtyBits.set(DIRTY_BIT_SCISSOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400715}
716
717const Rectangle &State::getScissor() const
718{
719 return mScissor;
720}
721
722bool State::isDitherEnabled() const
723{
724 return mBlend.dither;
725}
726
727void State::setDither(bool enabled)
728{
729 mBlend.dither = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400730 mDirtyBits.set(DIRTY_BIT_DITHER_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400731}
732
Jamie Madillb4b53c52015-02-03 15:22:48 -0500733bool State::isPrimitiveRestartEnabled() const
734{
735 return mPrimitiveRestart;
736}
737
738void State::setPrimitiveRestart(bool enabled)
739{
740 mPrimitiveRestart = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400741 mDirtyBits.set(DIRTY_BIT_PRIMITIVE_RESTART_ENABLED);
Jamie Madillb4b53c52015-02-03 15:22:48 -0500742}
743
Shannon Woods53a94a82014-06-24 15:20:36 -0400744void State::setEnableFeature(GLenum feature, bool enabled)
745{
746 switch (feature)
747 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700748 case GL_MULTISAMPLE_EXT:
749 setMultisampling(enabled);
750 break;
751 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
752 setSampleAlphaToOne(enabled);
753 break;
754 case GL_CULL_FACE:
755 setCullFace(enabled);
756 break;
757 case GL_POLYGON_OFFSET_FILL:
758 setPolygonOffsetFill(enabled);
759 break;
760 case GL_SAMPLE_ALPHA_TO_COVERAGE:
761 setSampleAlphaToCoverage(enabled);
762 break;
763 case GL_SAMPLE_COVERAGE:
764 setSampleCoverage(enabled);
765 break;
766 case GL_SCISSOR_TEST:
767 setScissorTest(enabled);
768 break;
769 case GL_STENCIL_TEST:
770 setStencilTest(enabled);
771 break;
772 case GL_DEPTH_TEST:
773 setDepthTest(enabled);
774 break;
775 case GL_BLEND:
776 setBlend(enabled);
777 break;
778 case GL_DITHER:
779 setDither(enabled);
780 break;
781 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
782 setPrimitiveRestart(enabled);
783 break;
784 case GL_RASTERIZER_DISCARD:
785 setRasterizerDiscard(enabled);
786 break;
787 case GL_SAMPLE_MASK:
788 setSampleMaskEnabled(enabled);
789 break;
790 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
791 mDebug.setOutputSynchronous(enabled);
792 break;
793 case GL_DEBUG_OUTPUT:
794 mDebug.setOutputEnabled(enabled);
795 break;
796 case GL_FRAMEBUFFER_SRGB_EXT:
797 setFramebufferSRGB(enabled);
798 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -0700799
800 // GLES1 emulation
801 case GL_ALPHA_TEST:
802 mGLES1State.mAlphaTestEnabled = enabled;
803 break;
Lingfeng Yang23dc90b2018-04-23 09:01:49 -0700804 case GL_TEXTURE_2D:
805 mGLES1State.mTexUnitEnables[mActiveSampler].set(TextureType::_2D, enabled);
806 break;
807 case GL_TEXTURE_CUBE_MAP:
808 mGLES1State.mTexUnitEnables[mActiveSampler].set(TextureType::CubeMap, enabled);
809 break;
Lingfeng Yangd0febe72018-05-17 22:36:52 -0700810 case GL_LIGHTING:
811 mGLES1State.mLightingEnabled = enabled;
812 break;
813 case GL_LIGHT0:
814 case GL_LIGHT1:
815 case GL_LIGHT2:
816 case GL_LIGHT3:
817 case GL_LIGHT4:
818 case GL_LIGHT5:
819 case GL_LIGHT6:
820 case GL_LIGHT7:
821 mGLES1State.mLights[feature - GL_LIGHT0].enabled = enabled;
822 break;
823 case GL_NORMALIZE:
824 mGLES1State.mNormalizeEnabled = enabled;
825 break;
826 case GL_RESCALE_NORMAL:
827 mGLES1State.mRescaleNormalEnabled = enabled;
828 break;
829 case GL_COLOR_MATERIAL:
830 mGLES1State.mColorMaterialEnabled = enabled;
831 break;
Lingfeng Yang060088a2018-05-30 20:40:57 -0700832 case GL_CLIP_PLANE0:
833 case GL_CLIP_PLANE1:
834 case GL_CLIP_PLANE2:
835 case GL_CLIP_PLANE3:
836 case GL_CLIP_PLANE4:
837 case GL_CLIP_PLANE5:
838 mGLES1State.mClipPlanes[feature - GL_CLIP_PLANE0].enabled = enabled;
839 break;
Lingfeng Yang7ba3f422018-06-01 09:43:04 -0700840 case GL_FOG:
841 mGLES1State.mFogEnabled = enabled;
842 break;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -0700843 case GL_POINT_SMOOTH:
844 mGLES1State.mPointSmoothEnabled = enabled;
845 break;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -0700846 case GL_LINE_SMOOTH:
847 mGLES1State.mLineSmoothEnabled = enabled;
848 break;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -0700849 case GL_POINT_SPRITE_OES:
850 mGLES1State.mPointSpriteEnabled = enabled;
851 break;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -0700852 case GL_COLOR_LOGIC_OP:
853 mGLES1State.mLogicOpEnabled = enabled;
854 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700855 default:
856 UNREACHABLE();
Shannon Woods53a94a82014-06-24 15:20:36 -0400857 }
858}
859
Jamie Madilldfde6ab2016-06-09 07:07:18 -0700860bool State::getEnableFeature(GLenum feature) const
Shannon Woods53a94a82014-06-24 15:20:36 -0400861{
862 switch (feature)
863 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700864 case GL_MULTISAMPLE_EXT:
865 return isMultisamplingEnabled();
866 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
867 return isSampleAlphaToOneEnabled();
868 case GL_CULL_FACE:
869 return isCullFaceEnabled();
870 case GL_POLYGON_OFFSET_FILL:
871 return isPolygonOffsetFillEnabled();
872 case GL_SAMPLE_ALPHA_TO_COVERAGE:
873 return isSampleAlphaToCoverageEnabled();
874 case GL_SAMPLE_COVERAGE:
875 return isSampleCoverageEnabled();
876 case GL_SCISSOR_TEST:
877 return isScissorTestEnabled();
878 case GL_STENCIL_TEST:
879 return isStencilTestEnabled();
880 case GL_DEPTH_TEST:
881 return isDepthTestEnabled();
882 case GL_BLEND:
883 return isBlendEnabled();
884 case GL_DITHER:
885 return isDitherEnabled();
886 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
887 return isPrimitiveRestartEnabled();
888 case GL_RASTERIZER_DISCARD:
889 return isRasterizerDiscardEnabled();
890 case GL_SAMPLE_MASK:
891 return isSampleMaskEnabled();
892 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
893 return mDebug.isOutputSynchronous();
894 case GL_DEBUG_OUTPUT:
895 return mDebug.isOutputEnabled();
896 case GL_BIND_GENERATES_RESOURCE_CHROMIUM:
897 return isBindGeneratesResourceEnabled();
898 case GL_CLIENT_ARRAYS_ANGLE:
899 return areClientArraysEnabled();
900 case GL_FRAMEBUFFER_SRGB_EXT:
901 return getFramebufferSRGB();
902 case GL_ROBUST_RESOURCE_INITIALIZATION_ANGLE:
903 return mRobustResourceInit;
904 case GL_PROGRAM_CACHE_ENABLED_ANGLE:
905 return mProgramBinaryCacheEnabled;
Jamie Madillc43be722017-07-13 16:22:14 -0400906
Lingfeng Yang13b708f2018-03-21 12:14:10 -0700907 // GLES1 emulation
908 case GL_ALPHA_TEST:
909 return mGLES1State.mAlphaTestEnabled;
Lingfeng Yang01074432018-04-16 10:19:51 -0700910 case GL_VERTEX_ARRAY:
911 return mGLES1State.mVertexArrayEnabled;
912 case GL_NORMAL_ARRAY:
913 return mGLES1State.mNormalArrayEnabled;
914 case GL_COLOR_ARRAY:
915 return mGLES1State.mColorArrayEnabled;
916 case GL_POINT_SIZE_ARRAY_OES:
917 return mGLES1State.mPointSizeArrayEnabled;
918 case GL_TEXTURE_COORD_ARRAY:
919 return mGLES1State.mTexCoordArrayEnabled[mGLES1State.mClientActiveTexture];
Lingfeng Yang23dc90b2018-04-23 09:01:49 -0700920 case GL_TEXTURE_2D:
921 return mGLES1State.mTexUnitEnables[mActiveSampler].test(TextureType::_2D);
922 case GL_TEXTURE_CUBE_MAP:
923 return mGLES1State.mTexUnitEnables[mActiveSampler].test(TextureType::CubeMap);
Lingfeng Yangd0febe72018-05-17 22:36:52 -0700924 case GL_LIGHTING:
925 return mGLES1State.mLightingEnabled;
926 case GL_LIGHT0:
927 case GL_LIGHT1:
928 case GL_LIGHT2:
929 case GL_LIGHT3:
930 case GL_LIGHT4:
931 case GL_LIGHT5:
932 case GL_LIGHT6:
933 case GL_LIGHT7:
934 return mGLES1State.mLights[feature - GL_LIGHT0].enabled;
935 case GL_NORMALIZE:
936 return mGLES1State.mNormalizeEnabled;
937 case GL_RESCALE_NORMAL:
938 return mGLES1State.mRescaleNormalEnabled;
939 case GL_COLOR_MATERIAL:
940 return mGLES1State.mColorMaterialEnabled;
Lingfeng Yang060088a2018-05-30 20:40:57 -0700941 case GL_CLIP_PLANE0:
942 case GL_CLIP_PLANE1:
943 case GL_CLIP_PLANE2:
944 case GL_CLIP_PLANE3:
945 case GL_CLIP_PLANE4:
946 case GL_CLIP_PLANE5:
947 return mGLES1State.mClipPlanes[feature - GL_CLIP_PLANE0].enabled;
Lingfeng Yang7ba3f422018-06-01 09:43:04 -0700948 case GL_FOG:
949 return mGLES1State.mFogEnabled;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -0700950 case GL_POINT_SMOOTH:
951 return mGLES1State.mPointSmoothEnabled;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -0700952 case GL_LINE_SMOOTH:
953 return mGLES1State.mLineSmoothEnabled;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -0700954 case GL_POINT_SPRITE_OES:
955 return mGLES1State.mPointSpriteEnabled;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -0700956 case GL_COLOR_LOGIC_OP:
957 return mGLES1State.mLogicOpEnabled;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700958 default:
959 UNREACHABLE();
960 return false;
Shannon Woods53a94a82014-06-24 15:20:36 -0400961 }
962}
963
964void State::setLineWidth(GLfloat width)
965{
966 mLineWidth = width;
Jamie Madill1b94d432015-08-07 13:23:23 -0400967 mDirtyBits.set(DIRTY_BIT_LINE_WIDTH);
Shannon Woods53a94a82014-06-24 15:20:36 -0400968}
969
Geoff Lang4b3f4162015-04-16 13:22:05 -0400970float State::getLineWidth() const
971{
972 return mLineWidth;
973}
974
Shannon Woods53a94a82014-06-24 15:20:36 -0400975void State::setGenerateMipmapHint(GLenum hint)
976{
977 mGenerateMipmapHint = hint;
Jamie Madill1b94d432015-08-07 13:23:23 -0400978 mDirtyBits.set(DIRTY_BIT_GENERATE_MIPMAP_HINT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400979}
980
981void State::setFragmentShaderDerivativeHint(GLenum hint)
982{
983 mFragmentShaderDerivativeHint = hint;
Jamie Madill1b94d432015-08-07 13:23:23 -0400984 mDirtyBits.set(DIRTY_BIT_SHADER_DERIVATIVE_HINT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400985 // TODO: Propagate the hint to shader translator so we can write
986 // ddx, ddx_coarse, or ddx_fine depending on the hint.
987 // Ignore for now. It is valid for implementations to ignore hint.
988}
989
Geoff Langfeb8c682017-02-13 16:07:35 -0500990bool State::areClientArraysEnabled() const
991{
992 return mClientArraysEnabled;
993}
994
Shannon Woods53a94a82014-06-24 15:20:36 -0400995void State::setViewportParams(GLint x, GLint y, GLsizei width, GLsizei height)
996{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700997 mViewport.x = x;
998 mViewport.y = y;
999 mViewport.width = width;
Shannon Woods53a94a82014-06-24 15:20:36 -04001000 mViewport.height = height;
Jamie Madill1b94d432015-08-07 13:23:23 -04001001 mDirtyBits.set(DIRTY_BIT_VIEWPORT);
Shannon Woods53a94a82014-06-24 15:20:36 -04001002}
1003
1004const Rectangle &State::getViewport() const
1005{
1006 return mViewport;
1007}
1008
1009void State::setActiveSampler(unsigned int active)
1010{
1011 mActiveSampler = active;
1012}
1013
1014unsigned int State::getActiveSampler() const
1015{
Cooper Partin4d61f7e2015-08-12 10:56:50 -07001016 return static_cast<unsigned int>(mActiveSampler);
Shannon Woods53a94a82014-06-24 15:20:36 -04001017}
1018
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001019void State::setSamplerTexture(const Context *context, TextureType type, Texture *texture)
Shannon Woods53a94a82014-06-24 15:20:36 -04001020{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001021 mSamplerTextures[type][mActiveSampler].set(context, texture);
Jamie Madill81c2e252017-09-09 23:32:46 -04001022 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
1023 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Shannon Woods53a94a82014-06-24 15:20:36 -04001024}
1025
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001026Texture *State::getTargetTexture(TextureType type) const
Jamie Madillc29968b2016-01-20 11:17:23 -05001027{
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001028 return getSamplerTexture(static_cast<unsigned int>(mActiveSampler), type);
Jamie Madillc29968b2016-01-20 11:17:23 -05001029}
1030
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001031Texture *State::getSamplerTexture(unsigned int sampler, TextureType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001032{
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001033 ASSERT(sampler < mSamplerTextures[type].size());
1034 return mSamplerTextures[type][sampler].get();
Shannon Woods53a94a82014-06-24 15:20:36 -04001035}
1036
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001037GLuint State::getSamplerTextureId(unsigned int sampler, TextureType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001038{
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001039 ASSERT(sampler < mSamplerTextures[type].size());
1040 return mSamplerTextures[type][sampler].id();
Shannon Woods53a94a82014-06-24 15:20:36 -04001041}
1042
Jamie Madilla02315b2017-02-23 14:14:47 -05001043void State::detachTexture(const Context *context, const TextureMap &zeroTextures, GLuint texture)
Shannon Woods53a94a82014-06-24 15:20:36 -04001044{
1045 // Textures have a detach method on State rather than a simple
1046 // removeBinding, because the zero/null texture objects are managed
1047 // separately, and don't have to go through the Context's maps or
1048 // the ResourceManager.
1049
1050 // [OpenGL ES 2.0.24] section 3.8 page 84:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001051 // If a texture object is deleted, it is as if all texture units which are bound to that texture
1052 // object are rebound to texture object zero
Shannon Woods53a94a82014-06-24 15:20:36 -04001053
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001054 for (TextureType type : angle::AllEnums<TextureType>())
Shannon Woods53a94a82014-06-24 15:20:36 -04001055 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001056 TextureBindingVector &textureVector = mSamplerTextures[type];
Jamie Madill81c2e252017-09-09 23:32:46 -04001057 for (BindingPointer<Texture> &binding : textureVector)
Shannon Woods53a94a82014-06-24 15:20:36 -04001058 {
Geoff Lang76b10c92014-09-05 16:28:14 -04001059 if (binding.id() == texture)
Shannon Woods53a94a82014-06-24 15:20:36 -04001060 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001061 Texture *zeroTexture = zeroTextures[type].get();
1062 ASSERT(zeroTexture != nullptr);
Jamie Madille6382c32014-11-07 15:05:26 -05001063 // Zero textures are the "default" textures instead of NULL
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001064 binding.set(context, zeroTexture);
Jamie Madill81c2e252017-09-09 23:32:46 -04001065 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
Shannon Woods53a94a82014-06-24 15:20:36 -04001066 }
1067 }
1068 }
1069
Xinghua Cao65ec0b22017-03-28 16:10:52 +08001070 for (auto &bindingImageUnit : mImageUnits)
1071 {
1072 if (bindingImageUnit.texture.id() == texture)
1073 {
1074 bindingImageUnit.texture.set(context, nullptr);
1075 bindingImageUnit.level = 0;
1076 bindingImageUnit.layered = false;
1077 bindingImageUnit.layer = 0;
1078 bindingImageUnit.access = GL_READ_ONLY;
1079 bindingImageUnit.format = GL_R32UI;
1080 break;
1081 }
1082 }
1083
Shannon Woods53a94a82014-06-24 15:20:36 -04001084 // [OpenGL ES 2.0.24] section 4.4 page 112:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001085 // If a texture object is deleted while its image is attached to the currently bound
1086 // framebuffer, then it is as if Texture2DAttachment had been called, with a texture of 0, for
1087 // each attachment point to which this image was attached in the currently bound framebuffer.
Shannon Woods53a94a82014-06-24 15:20:36 -04001088
Jamie Madill8693bdb2017-09-02 15:32:14 -04001089 if (mReadFramebuffer && mReadFramebuffer->detachTexture(context, texture))
Shannon Woods53a94a82014-06-24 15:20:36 -04001090 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001091 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
Shannon Woods53a94a82014-06-24 15:20:36 -04001092 }
1093
Jamie Madill8693bdb2017-09-02 15:32:14 -04001094 if (mDrawFramebuffer && mDrawFramebuffer->detachTexture(context, texture))
Shannon Woods53a94a82014-06-24 15:20:36 -04001095 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001096 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
Shannon Woods53a94a82014-06-24 15:20:36 -04001097 }
1098}
1099
Jamie Madill4928b7c2017-06-20 12:57:39 -04001100void State::initializeZeroTextures(const Context *context, const TextureMap &zeroTextures)
Jamie Madille6382c32014-11-07 15:05:26 -05001101{
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001102 for (TextureType type : angle::AllEnums<TextureType>())
Jamie Madille6382c32014-11-07 15:05:26 -05001103 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001104 for (size_t textureUnit = 0; textureUnit < mSamplerTextures[type].size(); ++textureUnit)
Jamie Madille6382c32014-11-07 15:05:26 -05001105 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001106 mSamplerTextures[type][textureUnit].set(context, zeroTextures[type].get());
Jamie Madille6382c32014-11-07 15:05:26 -05001107 }
1108 }
1109}
1110
Jamie Madill4928b7c2017-06-20 12:57:39 -04001111void State::setSamplerBinding(const Context *context, GLuint textureUnit, Sampler *sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001112{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001113 mSamplers[textureUnit].set(context, sampler);
Jamie Madill81c2e252017-09-09 23:32:46 -04001114 mDirtyBits.set(DIRTY_BIT_SAMPLER_BINDINGS);
1115 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Shannon Woods53a94a82014-06-24 15:20:36 -04001116}
1117
1118GLuint State::getSamplerId(GLuint textureUnit) const
1119{
Geoff Lang76b10c92014-09-05 16:28:14 -04001120 ASSERT(textureUnit < mSamplers.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001121 return mSamplers[textureUnit].id();
1122}
1123
Jamie Madill4928b7c2017-06-20 12:57:39 -04001124void State::detachSampler(const Context *context, GLuint sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001125{
1126 // [OpenGL ES 3.0.2] section 3.8.2 pages 123-124:
1127 // If a sampler object that is currently bound to one or more texture units is
1128 // deleted, it is as though BindSampler is called once for each texture unit to
1129 // which the sampler is bound, with unit set to the texture unit and sampler set to zero.
Jamie Madill81c2e252017-09-09 23:32:46 -04001130 for (BindingPointer<Sampler> &samplerBinding : mSamplers)
Shannon Woods53a94a82014-06-24 15:20:36 -04001131 {
Geoff Lang76b10c92014-09-05 16:28:14 -04001132 if (samplerBinding.id() == sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001133 {
Jamie Madill4928b7c2017-06-20 12:57:39 -04001134 samplerBinding.set(context, nullptr);
Jamie Madill81c2e252017-09-09 23:32:46 -04001135 mDirtyBits.set(DIRTY_BIT_SAMPLER_BINDINGS);
Shannon Woods53a94a82014-06-24 15:20:36 -04001136 }
1137 }
1138}
1139
Jamie Madill4928b7c2017-06-20 12:57:39 -04001140void State::setRenderbufferBinding(const Context *context, Renderbuffer *renderbuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001141{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001142 mRenderbuffer.set(context, renderbuffer);
Jamie Madill8693bdb2017-09-02 15:32:14 -04001143 mDirtyBits.set(DIRTY_BIT_RENDERBUFFER_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001144}
1145
1146GLuint State::getRenderbufferId() const
1147{
1148 return mRenderbuffer.id();
1149}
1150
Jamie Madilldfde6ab2016-06-09 07:07:18 -07001151Renderbuffer *State::getCurrentRenderbuffer() const
Shannon Woods53a94a82014-06-24 15:20:36 -04001152{
1153 return mRenderbuffer.get();
1154}
1155
Jamie Madilla02315b2017-02-23 14:14:47 -05001156void State::detachRenderbuffer(const Context *context, GLuint renderbuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001157{
1158 // [OpenGL ES 2.0.24] section 4.4 page 109:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001159 // If a renderbuffer that is currently bound to RENDERBUFFER is deleted, it is as though
1160 // BindRenderbuffer had been executed with the target RENDERBUFFER and name of zero.
Shannon Woods53a94a82014-06-24 15:20:36 -04001161
1162 if (mRenderbuffer.id() == renderbuffer)
1163 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001164 setRenderbufferBinding(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001165 }
1166
1167 // [OpenGL ES 2.0.24] section 4.4 page 111:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001168 // If a renderbuffer object is deleted while its image is attached to the currently bound
1169 // framebuffer, then it is as if FramebufferRenderbuffer had been called, with a renderbuffer of
1170 // 0, for each attachment point to which this image was attached in the currently bound
1171 // framebuffer.
Shannon Woods53a94a82014-06-24 15:20:36 -04001172
1173 Framebuffer *readFramebuffer = mReadFramebuffer;
1174 Framebuffer *drawFramebuffer = mDrawFramebuffer;
1175
Jamie Madill8693bdb2017-09-02 15:32:14 -04001176 if (readFramebuffer && readFramebuffer->detachRenderbuffer(context, renderbuffer))
Shannon Woods53a94a82014-06-24 15:20:36 -04001177 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001178 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
Shannon Woods53a94a82014-06-24 15:20:36 -04001179 }
1180
1181 if (drawFramebuffer && drawFramebuffer != readFramebuffer)
1182 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001183 if (drawFramebuffer->detachRenderbuffer(context, renderbuffer))
1184 {
1185 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
1186 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001187 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001188}
1189
1190void State::setReadFramebufferBinding(Framebuffer *framebuffer)
1191{
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001192 if (mReadFramebuffer == framebuffer)
1193 return;
1194
Shannon Woods53a94a82014-06-24 15:20:36 -04001195 mReadFramebuffer = framebuffer;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001196 mDirtyBits.set(DIRTY_BIT_READ_FRAMEBUFFER_BINDING);
1197
1198 if (mReadFramebuffer && mReadFramebuffer->hasAnyDirtyBit())
1199 {
1200 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
1201 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001202}
1203
1204void State::setDrawFramebufferBinding(Framebuffer *framebuffer)
1205{
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001206 if (mDrawFramebuffer == framebuffer)
1207 return;
1208
Shannon Woods53a94a82014-06-24 15:20:36 -04001209 mDrawFramebuffer = framebuffer;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001210 mDirtyBits.set(DIRTY_BIT_DRAW_FRAMEBUFFER_BINDING);
1211
1212 if (mDrawFramebuffer && mDrawFramebuffer->hasAnyDirtyBit())
1213 {
1214 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
1215 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001216}
1217
1218Framebuffer *State::getTargetFramebuffer(GLenum target) const
1219{
1220 switch (target)
1221 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001222 case GL_READ_FRAMEBUFFER_ANGLE:
1223 return mReadFramebuffer;
1224 case GL_DRAW_FRAMEBUFFER_ANGLE:
1225 case GL_FRAMEBUFFER:
1226 return mDrawFramebuffer;
1227 default:
1228 UNREACHABLE();
Yunchao Hef81ce4a2017-04-24 10:49:17 +08001229 return nullptr;
Shannon Woods53a94a82014-06-24 15:20:36 -04001230 }
1231}
1232
Jamie Madill51f40ec2016-06-15 14:06:00 -04001233Framebuffer *State::getReadFramebuffer() const
Shannon Woods53a94a82014-06-24 15:20:36 -04001234{
1235 return mReadFramebuffer;
1236}
1237
Shannon Woods53a94a82014-06-24 15:20:36 -04001238bool State::removeReadFramebufferBinding(GLuint framebuffer)
1239{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001240 if (mReadFramebuffer != nullptr && mReadFramebuffer->id() == framebuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001241 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001242 setReadFramebufferBinding(nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001243 return true;
1244 }
1245
1246 return false;
1247}
1248
1249bool State::removeDrawFramebufferBinding(GLuint framebuffer)
1250{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001251 if (mReadFramebuffer != nullptr && mDrawFramebuffer->id() == framebuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001252 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001253 setDrawFramebufferBinding(nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001254 return true;
1255 }
1256
1257 return false;
1258}
1259
Jamie Madill7267aa62018-04-17 15:28:21 -04001260void State::setVertexArrayBinding(const Context *context, VertexArray *vertexArray)
Shannon Woods53a94a82014-06-24 15:20:36 -04001261{
James Darpiniane8a93c62018-01-04 18:02:24 -08001262 if (mVertexArray == vertexArray)
1263 return;
1264 if (mVertexArray)
Jamie Madillbf5177d2018-08-21 12:58:20 -04001265 mVertexArray->onBindingChanged(context, -1);
Shannon Woods53a94a82014-06-24 15:20:36 -04001266 mVertexArray = vertexArray;
James Darpiniane8a93c62018-01-04 18:02:24 -08001267 if (vertexArray)
Jamie Madillbf5177d2018-08-21 12:58:20 -04001268 vertexArray->onBindingChanged(context, 1);
Jamie Madill0b9e9032015-08-17 11:51:52 +00001269 mDirtyBits.set(DIRTY_BIT_VERTEX_ARRAY_BINDING);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001270
1271 if (mVertexArray && mVertexArray->hasAnyDirtyBit())
1272 {
1273 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1274 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001275}
1276
1277GLuint State::getVertexArrayId() const
1278{
Yunchao He4f285442017-04-21 12:15:49 +08001279 ASSERT(mVertexArray != nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001280 return mVertexArray->id();
1281}
1282
Jamie Madill7267aa62018-04-17 15:28:21 -04001283bool State::removeVertexArrayBinding(const Context *context, GLuint vertexArray)
Shannon Woods53a94a82014-06-24 15:20:36 -04001284{
James Darpiniane8a93c62018-01-04 18:02:24 -08001285 if (mVertexArray && mVertexArray->id() == vertexArray)
Shannon Woods53a94a82014-06-24 15:20:36 -04001286 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001287 mVertexArray->onBindingChanged(context, -1);
Yunchao Hed7297bf2017-04-19 15:27:10 +08001288 mVertexArray = nullptr;
Jamie Madill0b9e9032015-08-17 11:51:52 +00001289 mDirtyBits.set(DIRTY_BIT_VERTEX_ARRAY_BINDING);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001290 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001291 return true;
1292 }
1293
1294 return false;
1295}
1296
Jamie Madill4928b7c2017-06-20 12:57:39 -04001297void State::bindVertexBuffer(const Context *context,
1298 GLuint bindingIndex,
Shao80957d92017-02-20 21:25:59 +08001299 Buffer *boundBuffer,
1300 GLintptr offset,
1301 GLsizei stride)
1302{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001303 getVertexArray()->bindVertexBuffer(context, bindingIndex, boundBuffer, offset, stride);
Shao80957d92017-02-20 21:25:59 +08001304 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1305}
1306
Shaodde78e82017-05-22 14:13:27 +08001307void State::setVertexAttribBinding(const Context *context, GLuint attribIndex, GLuint bindingIndex)
Shao80957d92017-02-20 21:25:59 +08001308{
Shaodde78e82017-05-22 14:13:27 +08001309 getVertexArray()->setVertexAttribBinding(context, attribIndex, bindingIndex);
Shao80957d92017-02-20 21:25:59 +08001310 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1311}
1312
1313void State::setVertexAttribFormat(GLuint attribIndex,
1314 GLint size,
1315 GLenum type,
1316 bool normalized,
1317 bool pureInteger,
1318 GLuint relativeOffset)
1319{
1320 getVertexArray()->setVertexAttribFormat(attribIndex, size, type, normalized, pureInteger,
1321 relativeOffset);
1322 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1323}
1324
1325void State::setVertexBindingDivisor(GLuint bindingIndex, GLuint divisor)
1326{
1327 getVertexArray()->setVertexBindingDivisor(bindingIndex, divisor);
1328 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1329}
1330
Jamie Madill6c1f6712017-02-14 19:08:04 -05001331void State::setProgram(const Context *context, Program *newProgram)
Shannon Woods53a94a82014-06-24 15:20:36 -04001332{
Geoff Lang7dd2e102014-11-10 15:19:26 -05001333 if (mProgram != newProgram)
Shannon Woods53a94a82014-06-24 15:20:36 -04001334 {
Geoff Lang7dd2e102014-11-10 15:19:26 -05001335 if (mProgram)
1336 {
Jamie Madill6c1f6712017-02-14 19:08:04 -05001337 mProgram->release(context);
Geoff Lang7dd2e102014-11-10 15:19:26 -05001338 }
1339
1340 mProgram = newProgram;
1341
1342 if (mProgram)
1343 {
1344 newProgram->addRef();
Jamie Madill81c2e252017-09-09 23:32:46 -04001345 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Geoff Lang7dd2e102014-11-10 15:19:26 -05001346 }
Jamie Madilla779b612017-07-24 11:46:05 -04001347 mDirtyBits.set(DIRTY_BIT_PROGRAM_EXECUTABLE);
1348 mDirtyBits.set(DIRTY_BIT_PROGRAM_BINDING);
Jamie Madill70aeda42018-08-20 12:17:40 -04001349 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM);
Shannon Woods53a94a82014-06-24 15:20:36 -04001350 }
1351}
1352
Jamie Madill4928b7c2017-06-20 12:57:39 -04001353void State::setTransformFeedbackBinding(const Context *context,
1354 TransformFeedback *transformFeedback)
Shannon Woods53a94a82014-06-24 15:20:36 -04001355{
James Darpiniane8a93c62018-01-04 18:02:24 -08001356 if (transformFeedback == mTransformFeedback.get())
1357 return;
1358 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -04001359 mTransformFeedback->onBindingChanged(context, false);
Jamie Madill4928b7c2017-06-20 12:57:39 -04001360 mTransformFeedback.set(context, transformFeedback);
James Darpiniane8a93c62018-01-04 18:02:24 -08001361 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -04001362 mTransformFeedback->onBindingChanged(context, true);
Geoff Langded79232017-11-28 15:21:11 -05001363 mDirtyBits.set(DIRTY_BIT_TRANSFORM_FEEDBACK_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001364}
1365
Gregoire Payen de La Garanderie52742022015-02-04 14:55:39 +00001366bool State::isTransformFeedbackActiveUnpaused() const
1367{
Jamie Madill4166f012018-05-31 14:53:30 -04001368 TransformFeedback *curTransformFeedback = mTransformFeedback.get();
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001369 return curTransformFeedback && curTransformFeedback->isActive() &&
1370 !curTransformFeedback->isPaused();
Gregoire Payen de La Garanderie52742022015-02-04 14:55:39 +00001371}
1372
Jamie Madill4928b7c2017-06-20 12:57:39 -04001373bool State::removeTransformFeedbackBinding(const Context *context, GLuint transformFeedback)
Shannon Woods53a94a82014-06-24 15:20:36 -04001374{
1375 if (mTransformFeedback.id() == transformFeedback)
1376 {
James Darpiniane8a93c62018-01-04 18:02:24 -08001377 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -04001378 mTransformFeedback->onBindingChanged(context, false);
Jamie Madill4928b7c2017-06-20 12:57:39 -04001379 mTransformFeedback.set(context, nullptr);
Corentin Walleza2257da2016-04-19 16:43:12 -04001380 return true;
Shannon Woods53a94a82014-06-24 15:20:36 -04001381 }
Corentin Walleza2257da2016-04-19 16:43:12 -04001382
1383 return false;
Shannon Woods53a94a82014-06-24 15:20:36 -04001384}
1385
Yunchao Hea336b902017-08-02 16:05:21 +08001386void State::setProgramPipelineBinding(const Context *context, ProgramPipeline *pipeline)
1387{
1388 mProgramPipeline.set(context, pipeline);
1389}
1390
1391void State::detachProgramPipeline(const Context *context, GLuint pipeline)
1392{
1393 mProgramPipeline.set(context, nullptr);
1394}
1395
Corentin Wallezad3ae902018-03-09 13:40:42 -05001396bool State::isQueryActive(QueryType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001397{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001398 const Query *query = mActiveQueries[type].get();
1399 if (query != nullptr)
Shannon Woods53a94a82014-06-24 15:20:36 -04001400 {
Corentin Wallezad3ae902018-03-09 13:40:42 -05001401 return true;
1402 }
1403
1404 QueryType alternativeType;
1405 if (GetAlternativeQueryType(type, &alternativeType))
1406 {
1407 query = mActiveQueries[alternativeType].get();
1408 return query != nullptr;
Ian Ewell3ffd78b2016-01-22 16:09:42 -05001409 }
1410
1411 return false;
1412}
1413
1414bool State::isQueryActive(Query *query) const
1415{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001416 for (auto &queryPointer : mActiveQueries)
Ian Ewell3ffd78b2016-01-22 16:09:42 -05001417 {
Corentin Wallezad3ae902018-03-09 13:40:42 -05001418 if (queryPointer.get() == query)
Shannon Woods53a94a82014-06-24 15:20:36 -04001419 {
1420 return true;
1421 }
1422 }
1423
1424 return false;
1425}
1426
Corentin Wallezad3ae902018-03-09 13:40:42 -05001427void State::setActiveQuery(const Context *context, QueryType type, Query *query)
Shannon Woods53a94a82014-06-24 15:20:36 -04001428{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001429 mActiveQueries[type].set(context, query);
Shannon Woods53a94a82014-06-24 15:20:36 -04001430}
1431
Corentin Wallezad3ae902018-03-09 13:40:42 -05001432GLuint State::getActiveQueryId(QueryType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001433{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001434 const Query *query = getActiveQuery(type);
Shannon Woods53a94a82014-06-24 15:20:36 -04001435 return (query ? query->id() : 0u);
1436}
1437
Corentin Wallezad3ae902018-03-09 13:40:42 -05001438Query *State::getActiveQuery(QueryType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001439{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001440 return mActiveQueries[type].get();
Shannon Woods53a94a82014-06-24 15:20:36 -04001441}
1442
Corentin Wallez336129f2017-10-17 15:55:40 -04001443void State::setBufferBinding(const Context *context, BufferBinding target, Buffer *buffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001444{
Corentin Wallez336129f2017-10-17 15:55:40 -04001445 switch (target)
1446 {
1447 case BufferBinding::PixelPack:
Jamie Madillbf5177d2018-08-21 12:58:20 -04001448 UpdateBufferBinding(context, &mBoundBuffers[target], buffer, target);
Corentin Wallez336129f2017-10-17 15:55:40 -04001449 mDirtyBits.set(DIRTY_BIT_PACK_BUFFER_BINDING);
1450 break;
1451 case BufferBinding::PixelUnpack:
Jamie Madillbf5177d2018-08-21 12:58:20 -04001452 UpdateBufferBinding(context, &mBoundBuffers[target], buffer, target);
Corentin Wallez336129f2017-10-17 15:55:40 -04001453 mDirtyBits.set(DIRTY_BIT_UNPACK_BUFFER_BINDING);
1454 break;
1455 case BufferBinding::DrawIndirect:
Jamie Madillbf5177d2018-08-21 12:58:20 -04001456 UpdateBufferBinding(context, &mBoundBuffers[target], buffer, target);
Corentin Wallez336129f2017-10-17 15:55:40 -04001457 mDirtyBits.set(DIRTY_BIT_DRAW_INDIRECT_BUFFER_BINDING);
1458 break;
Qin Jiajiaa98a2812017-11-30 18:12:06 +08001459 case BufferBinding::DispatchIndirect:
Jamie Madillbf5177d2018-08-21 12:58:20 -04001460 UpdateBufferBinding(context, &mBoundBuffers[target], buffer, target);
Qin Jiajiaa98a2812017-11-30 18:12:06 +08001461 mDirtyBits.set(DIRTY_BIT_DISPATCH_INDIRECT_BUFFER_BINDING);
1462 break;
Corentin Wallez336129f2017-10-17 15:55:40 -04001463 case BufferBinding::ElementArray:
1464 getVertexArray()->setElementArrayBuffer(context, buffer);
1465 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1466 break;
Xinghua Cao10a4d432017-11-28 14:46:26 +08001467 case BufferBinding::ShaderStorage:
Jamie Madillbf5177d2018-08-21 12:58:20 -04001468 UpdateBufferBinding(context, &mBoundBuffers[target], buffer, target);
Xinghua Cao10a4d432017-11-28 14:46:26 +08001469 mDirtyBits.set(DIRTY_BIT_SHADER_STORAGE_BUFFER_BINDING);
1470 break;
Corentin Wallez336129f2017-10-17 15:55:40 -04001471 default:
Jamie Madillbf5177d2018-08-21 12:58:20 -04001472 UpdateBufferBinding(context, &mBoundBuffers[target], buffer, target);
Corentin Wallez336129f2017-10-17 15:55:40 -04001473 break;
1474 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001475}
James Darpiniane8a93c62018-01-04 18:02:24 -08001476
Corentin Wallez336129f2017-10-17 15:55:40 -04001477void State::setIndexedBufferBinding(const Context *context,
1478 BufferBinding target,
1479 GLuint index,
1480 Buffer *buffer,
1481 GLintptr offset,
1482 GLsizeiptr size)
Jiajia Qin9d7d0b12016-11-29 16:30:31 +08001483{
Corentin Wallez336129f2017-10-17 15:55:40 -04001484 setBufferBinding(context, target, buffer);
Jiajia Qin9d7d0b12016-11-29 16:30:31 +08001485
Corentin Wallez336129f2017-10-17 15:55:40 -04001486 switch (target)
1487 {
1488 case BufferBinding::TransformFeedback:
1489 mTransformFeedback->bindIndexedBuffer(context, index, buffer, offset, size);
James Darpiniane8a93c62018-01-04 18:02:24 -08001490 setBufferBinding(context, target, buffer);
Corentin Wallez336129f2017-10-17 15:55:40 -04001491 break;
1492 case BufferBinding::Uniform:
Jamie Madillbf5177d2018-08-21 12:58:20 -04001493 UpdateIndexedBufferBinding(context, &mUniformBuffers[index], buffer, target, offset,
1494 size);
Jamie Madillf4141212017-12-12 15:08:07 -05001495 mDirtyBits.set(DIRTY_BIT_UNIFORM_BUFFER_BINDINGS);
Corentin Wallez336129f2017-10-17 15:55:40 -04001496 break;
1497 case BufferBinding::AtomicCounter:
Jamie Madillbf5177d2018-08-21 12:58:20 -04001498 UpdateIndexedBufferBinding(context, &mAtomicCounterBuffers[index], buffer, target,
1499 offset, size);
Corentin Wallez336129f2017-10-17 15:55:40 -04001500 break;
1501 case BufferBinding::ShaderStorage:
Jamie Madillbf5177d2018-08-21 12:58:20 -04001502 UpdateIndexedBufferBinding(context, &mShaderStorageBuffers[index], buffer, target,
1503 offset, size);
Corentin Wallez336129f2017-10-17 15:55:40 -04001504 break;
1505 default:
1506 UNREACHABLE();
1507 break;
1508 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001509}
1510
Geoff Lang5d124a62015-09-15 13:03:27 -04001511const OffsetBindingPointer<Buffer> &State::getIndexedUniformBuffer(size_t index) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001512{
Shannon Woodsf3acaf92014-09-23 18:07:11 -04001513 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
Geoff Lang5d124a62015-09-15 13:03:27 -04001514 return mUniformBuffers[index];
Gregoire Payen de La Garanderie68694e92015-03-24 14:03:37 +00001515}
1516
Jiajia Qin6eafb042016-12-27 17:04:07 +08001517const OffsetBindingPointer<Buffer> &State::getIndexedAtomicCounterBuffer(size_t index) const
1518{
1519 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
1520 return mAtomicCounterBuffers[index];
1521}
1522
Jiajia Qinf546e7d2017-03-27 14:12:59 +08001523const OffsetBindingPointer<Buffer> &State::getIndexedShaderStorageBuffer(size_t index) const
1524{
1525 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
1526 return mShaderStorageBuffers[index];
1527}
1528
Corentin Wallez336129f2017-10-17 15:55:40 -04001529Buffer *State::getTargetBuffer(BufferBinding target) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001530{
1531 switch (target)
1532 {
Corentin Wallez336129f2017-10-17 15:55:40 -04001533 case BufferBinding::ElementArray:
1534 return getVertexArray()->getElementArrayBuffer().get();
Corentin Wallez336129f2017-10-17 15:55:40 -04001535 default:
1536 return mBoundBuffers[target].get();
Shannon Woods53a94a82014-06-24 15:20:36 -04001537 }
1538}
1539
James Darpinian4d9d4832018-03-13 12:43:28 -07001540void State::detachBuffer(const Context *context, const Buffer *buffer)
Yuly Novikov5807a532015-12-03 13:01:22 -05001541{
James Darpinian4d9d4832018-03-13 12:43:28 -07001542 if (!buffer->isBound())
1543 {
1544 return;
1545 }
1546 GLuint bufferName = buffer->id();
James Darpiniane8a93c62018-01-04 18:02:24 -08001547 for (auto target : angle::AllEnums<BufferBinding>())
Yuly Novikov5807a532015-12-03 13:01:22 -05001548 {
James Darpiniane8a93c62018-01-04 18:02:24 -08001549 if (mBoundBuffers[target].id() == bufferName)
Yuly Novikov5807a532015-12-03 13:01:22 -05001550 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001551 UpdateBufferBinding(context, &mBoundBuffers[target], nullptr, target);
Yuly Novikov5807a532015-12-03 13:01:22 -05001552 }
1553 }
1554
1555 TransformFeedback *curTransformFeedback = getCurrentTransformFeedback();
1556 if (curTransformFeedback)
1557 {
Jamie Madill4928b7c2017-06-20 12:57:39 -04001558 curTransformFeedback->detachBuffer(context, bufferName);
Yuly Novikov5807a532015-12-03 13:01:22 -05001559 }
1560
Jamie Madill4928b7c2017-06-20 12:57:39 -04001561 getVertexArray()->detachBuffer(context, bufferName);
James Darpiniane8a93c62018-01-04 18:02:24 -08001562
1563 for (auto &buf : mUniformBuffers)
1564 {
1565 if (buf.id() == bufferName)
1566 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001567 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::Uniform, 0, 0);
James Darpiniane8a93c62018-01-04 18:02:24 -08001568 }
1569 }
1570
1571 for (auto &buf : mAtomicCounterBuffers)
1572 {
1573 if (buf.id() == bufferName)
1574 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001575 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::AtomicCounter, 0, 0);
James Darpiniane8a93c62018-01-04 18:02:24 -08001576 }
1577 }
1578
1579 for (auto &buf : mShaderStorageBuffers)
1580 {
1581 if (buf.id() == bufferName)
1582 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001583 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::ShaderStorage, 0, 0);
James Darpiniane8a93c62018-01-04 18:02:24 -08001584 }
1585 }
Yuly Novikov5807a532015-12-03 13:01:22 -05001586}
1587
Shannon Woods53a94a82014-06-24 15:20:36 -04001588void State::setEnableVertexAttribArray(unsigned int attribNum, bool enabled)
1589{
1590 getVertexArray()->enableAttribute(attribNum, enabled);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001591 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001592}
1593
1594void State::setVertexAttribf(GLuint index, const GLfloat values[4])
1595{
Shannon Woods23e05002014-09-22 19:07:27 -04001596 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001597 mVertexAttribCurrentValues[index].setFloatValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001598 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1599 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001600 mCurrentValuesTypeMask.setIndex(GL_FLOAT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001601}
1602
1603void State::setVertexAttribu(GLuint index, const GLuint values[4])
1604{
Shannon Woods23e05002014-09-22 19:07:27 -04001605 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001606 mVertexAttribCurrentValues[index].setUnsignedIntValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001607 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1608 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001609 mCurrentValuesTypeMask.setIndex(GL_UNSIGNED_INT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001610}
1611
1612void State::setVertexAttribi(GLuint index, const GLint values[4])
1613{
Shannon Woods23e05002014-09-22 19:07:27 -04001614 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001615 mVertexAttribCurrentValues[index].setIntValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001616 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1617 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001618 mCurrentValuesTypeMask.setIndex(GL_INT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001619}
1620
Shaodde78e82017-05-22 14:13:27 +08001621void State::setVertexAttribPointer(const Context *context,
1622 unsigned int attribNum,
1623 Buffer *boundBuffer,
1624 GLint size,
1625 GLenum type,
1626 bool normalized,
1627 bool pureInteger,
1628 GLsizei stride,
1629 const void *pointer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001630{
Shaodde78e82017-05-22 14:13:27 +08001631 getVertexArray()->setVertexAttribPointer(context, attribNum, boundBuffer, size, type,
1632 normalized, pureInteger, stride, pointer);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001633 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Jamie Madill0b9e9032015-08-17 11:51:52 +00001634}
1635
Shaodde78e82017-05-22 14:13:27 +08001636void State::setVertexAttribDivisor(const Context *context, GLuint index, GLuint divisor)
Jamie Madill0b9e9032015-08-17 11:51:52 +00001637{
Shaodde78e82017-05-22 14:13:27 +08001638 getVertexArray()->setVertexAttribDivisor(context, index, divisor);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001639 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001640}
1641
Jamie Madill6de51852017-04-12 09:53:01 -04001642const VertexAttribCurrentValueData &State::getVertexAttribCurrentValue(size_t attribNum) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001643{
Jamie Madill6de51852017-04-12 09:53:01 -04001644 ASSERT(attribNum < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001645 return mVertexAttribCurrentValues[attribNum];
1646}
1647
Jamie Madillcac94a92017-11-10 10:09:32 -05001648const std::vector<VertexAttribCurrentValueData> &State::getVertexAttribCurrentValues() const
1649{
1650 return mVertexAttribCurrentValues;
1651}
1652
Shannon Woods53a94a82014-06-24 15:20:36 -04001653const void *State::getVertexAttribPointer(unsigned int attribNum) const
1654{
1655 return getVertexArray()->getVertexAttribute(attribNum).pointer;
1656}
1657
1658void State::setPackAlignment(GLint alignment)
1659{
1660 mPack.alignment = alignment;
Jamie Madillc67323a2017-11-02 23:11:41 -04001661 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001662}
1663
1664GLint State::getPackAlignment() const
1665{
1666 return mPack.alignment;
1667}
1668
1669void State::setPackReverseRowOrder(bool reverseRowOrder)
1670{
1671 mPack.reverseRowOrder = reverseRowOrder;
Jamie Madillc67323a2017-11-02 23:11:41 -04001672 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001673}
1674
1675bool State::getPackReverseRowOrder() const
1676{
1677 return mPack.reverseRowOrder;
1678}
1679
Minmin Gongadff67b2015-10-14 10:34:45 -04001680void State::setPackRowLength(GLint rowLength)
1681{
1682 mPack.rowLength = rowLength;
Jamie Madillc67323a2017-11-02 23:11:41 -04001683 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001684}
1685
1686GLint State::getPackRowLength() const
1687{
1688 return mPack.rowLength;
1689}
1690
1691void State::setPackSkipRows(GLint skipRows)
1692{
1693 mPack.skipRows = skipRows;
Jamie Madillc67323a2017-11-02 23:11:41 -04001694 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001695}
1696
1697GLint State::getPackSkipRows() const
1698{
1699 return mPack.skipRows;
1700}
1701
1702void State::setPackSkipPixels(GLint skipPixels)
1703{
1704 mPack.skipPixels = skipPixels;
Jamie Madillc67323a2017-11-02 23:11:41 -04001705 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001706}
1707
1708GLint State::getPackSkipPixels() const
1709{
1710 return mPack.skipPixels;
1711}
1712
Shannon Woods53a94a82014-06-24 15:20:36 -04001713const PixelPackState &State::getPackState() const
1714{
1715 return mPack;
1716}
1717
Jamie Madill87de3622015-03-16 10:41:44 -04001718PixelPackState &State::getPackState()
1719{
1720 return mPack;
1721}
1722
Shannon Woods53a94a82014-06-24 15:20:36 -04001723void State::setUnpackAlignment(GLint alignment)
1724{
1725 mUnpack.alignment = alignment;
Jamie Madillc67323a2017-11-02 23:11:41 -04001726 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001727}
1728
1729GLint State::getUnpackAlignment() const
1730{
1731 return mUnpack.alignment;
1732}
1733
Minmin Gongb8aee3b2015-01-27 14:42:36 -08001734void State::setUnpackRowLength(GLint rowLength)
1735{
1736 mUnpack.rowLength = rowLength;
Jamie Madillc67323a2017-11-02 23:11:41 -04001737 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongb8aee3b2015-01-27 14:42:36 -08001738}
1739
1740GLint State::getUnpackRowLength() const
1741{
1742 return mUnpack.rowLength;
1743}
1744
Minmin Gongadff67b2015-10-14 10:34:45 -04001745void State::setUnpackImageHeight(GLint imageHeight)
1746{
1747 mUnpack.imageHeight = imageHeight;
Jamie Madillc67323a2017-11-02 23:11:41 -04001748 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001749}
1750
1751GLint State::getUnpackImageHeight() const
1752{
1753 return mUnpack.imageHeight;
1754}
1755
1756void State::setUnpackSkipImages(GLint skipImages)
1757{
1758 mUnpack.skipImages = skipImages;
Jamie Madillc67323a2017-11-02 23:11:41 -04001759 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001760}
1761
1762GLint State::getUnpackSkipImages() const
1763{
1764 return mUnpack.skipImages;
1765}
1766
1767void State::setUnpackSkipRows(GLint skipRows)
1768{
1769 mUnpack.skipRows = skipRows;
Jamie Madillc67323a2017-11-02 23:11:41 -04001770 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001771}
1772
1773GLint State::getUnpackSkipRows() const
1774{
1775 return mUnpack.skipRows;
1776}
1777
1778void State::setUnpackSkipPixels(GLint skipPixels)
1779{
1780 mUnpack.skipPixels = skipPixels;
Jamie Madillc67323a2017-11-02 23:11:41 -04001781 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001782}
1783
1784GLint State::getUnpackSkipPixels() const
1785{
1786 return mUnpack.skipPixels;
1787}
1788
Shannon Woods53a94a82014-06-24 15:20:36 -04001789const PixelUnpackState &State::getUnpackState() const
1790{
1791 return mUnpack;
1792}
1793
Jamie Madill67102f02015-03-16 10:41:42 -04001794PixelUnpackState &State::getUnpackState()
1795{
1796 return mUnpack;
1797}
1798
Geoff Lang70d0f492015-12-10 17:45:46 -05001799const Debug &State::getDebug() const
1800{
1801 return mDebug;
1802}
1803
1804Debug &State::getDebug()
1805{
1806 return mDebug;
1807}
1808
Sami Väisänena797e062016-05-12 15:23:40 +03001809void State::setCoverageModulation(GLenum components)
1810{
1811 mCoverageModulation = components;
1812 mDirtyBits.set(DIRTY_BIT_COVERAGE_MODULATION);
1813}
1814
1815GLenum State::getCoverageModulation() const
1816{
1817 return mCoverageModulation;
1818}
1819
Sami Väisänene45e53b2016-05-25 10:36:04 +03001820void State::loadPathRenderingMatrix(GLenum matrixMode, const GLfloat *matrix)
1821{
1822 if (matrixMode == GL_PATH_MODELVIEW_CHROMIUM)
1823 {
1824 memcpy(mPathMatrixMV, matrix, 16 * sizeof(GLfloat));
1825 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING_MATRIX_MV);
1826 }
1827 else if (matrixMode == GL_PATH_PROJECTION_CHROMIUM)
1828 {
1829 memcpy(mPathMatrixProj, matrix, 16 * sizeof(GLfloat));
1830 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING_MATRIX_PROJ);
1831 }
1832 else
1833 {
1834 UNREACHABLE();
1835 }
1836}
1837
1838const GLfloat *State::getPathRenderingMatrix(GLenum which) const
1839{
1840 if (which == GL_PATH_MODELVIEW_MATRIX_CHROMIUM)
1841 {
1842 return mPathMatrixMV;
1843 }
1844 else if (which == GL_PATH_PROJECTION_MATRIX_CHROMIUM)
1845 {
1846 return mPathMatrixProj;
1847 }
1848
1849 UNREACHABLE();
1850 return nullptr;
1851}
1852
1853void State::setPathStencilFunc(GLenum func, GLint ref, GLuint mask)
1854{
1855 mPathStencilFunc = func;
1856 mPathStencilRef = ref;
1857 mPathStencilMask = mask;
1858 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING_STENCIL_STATE);
1859}
1860
1861GLenum State::getPathStencilFunc() const
1862{
1863 return mPathStencilFunc;
1864}
1865
1866GLint State::getPathStencilRef() const
1867{
1868 return mPathStencilRef;
1869}
1870
1871GLuint State::getPathStencilMask() const
1872{
1873 return mPathStencilMask;
1874}
1875
Geoff Lang1d2c41d2016-10-19 16:14:46 -07001876void State::setFramebufferSRGB(bool sRGB)
1877{
1878 mFramebufferSRGB = sRGB;
1879 mDirtyBits.set(DIRTY_BIT_FRAMEBUFFER_SRGB);
1880}
1881
1882bool State::getFramebufferSRGB() const
1883{
1884 return mFramebufferSRGB;
1885}
1886
jchen1082af6202018-06-22 10:59:52 +08001887void State::setMaxShaderCompilerThreads(GLuint count)
1888{
1889 mMaxShaderCompilerThreads = count;
1890}
1891
1892GLuint State::getMaxShaderCompilerThreads() const
1893{
1894 return mMaxShaderCompilerThreads;
1895}
1896
Shannon Woods53a94a82014-06-24 15:20:36 -04001897void State::getBooleanv(GLenum pname, GLboolean *params)
1898{
1899 switch (pname)
1900 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001901 case GL_SAMPLE_COVERAGE_INVERT:
1902 *params = mSampleCoverageInvert;
1903 break;
1904 case GL_DEPTH_WRITEMASK:
1905 *params = mDepthStencil.depthMask;
1906 break;
1907 case GL_COLOR_WRITEMASK:
1908 params[0] = mBlend.colorMaskRed;
1909 params[1] = mBlend.colorMaskGreen;
1910 params[2] = mBlend.colorMaskBlue;
1911 params[3] = mBlend.colorMaskAlpha;
1912 break;
1913 case GL_CULL_FACE:
1914 *params = mRasterizer.cullFace;
1915 break;
1916 case GL_POLYGON_OFFSET_FILL:
1917 *params = mRasterizer.polygonOffsetFill;
1918 break;
1919 case GL_SAMPLE_ALPHA_TO_COVERAGE:
1920 *params = mBlend.sampleAlphaToCoverage;
1921 break;
1922 case GL_SAMPLE_COVERAGE:
1923 *params = mSampleCoverage;
1924 break;
1925 case GL_SAMPLE_MASK:
1926 *params = mSampleMask;
1927 break;
1928 case GL_SCISSOR_TEST:
1929 *params = mScissorTest;
1930 break;
1931 case GL_STENCIL_TEST:
1932 *params = mDepthStencil.stencilTest;
1933 break;
1934 case GL_DEPTH_TEST:
1935 *params = mDepthStencil.depthTest;
1936 break;
1937 case GL_BLEND:
1938 *params = mBlend.blend;
1939 break;
1940 case GL_DITHER:
1941 *params = mBlend.dither;
1942 break;
1943 case GL_TRANSFORM_FEEDBACK_ACTIVE:
1944 *params = getCurrentTransformFeedback()->isActive() ? GL_TRUE : GL_FALSE;
1945 break;
1946 case GL_TRANSFORM_FEEDBACK_PAUSED:
1947 *params = getCurrentTransformFeedback()->isPaused() ? GL_TRUE : GL_FALSE;
1948 break;
1949 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
1950 *params = mPrimitiveRestart;
1951 break;
1952 case GL_RASTERIZER_DISCARD:
1953 *params = isRasterizerDiscardEnabled() ? GL_TRUE : GL_FALSE;
1954 break;
1955 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
1956 *params = mDebug.isOutputSynchronous() ? GL_TRUE : GL_FALSE;
1957 break;
1958 case GL_DEBUG_OUTPUT:
1959 *params = mDebug.isOutputEnabled() ? GL_TRUE : GL_FALSE;
1960 break;
1961 case GL_MULTISAMPLE_EXT:
1962 *params = mMultiSampling;
1963 break;
1964 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
1965 *params = mSampleAlphaToOne;
1966 break;
1967 case GL_BIND_GENERATES_RESOURCE_CHROMIUM:
1968 *params = isBindGeneratesResourceEnabled() ? GL_TRUE : GL_FALSE;
1969 break;
1970 case GL_CLIENT_ARRAYS_ANGLE:
1971 *params = areClientArraysEnabled() ? GL_TRUE : GL_FALSE;
1972 break;
1973 case GL_FRAMEBUFFER_SRGB_EXT:
1974 *params = getFramebufferSRGB() ? GL_TRUE : GL_FALSE;
1975 break;
1976 case GL_ROBUST_RESOURCE_INITIALIZATION_ANGLE:
1977 *params = mRobustResourceInit ? GL_TRUE : GL_FALSE;
1978 break;
1979 case GL_PROGRAM_CACHE_ENABLED_ANGLE:
1980 *params = mProgramBinaryCacheEnabled ? GL_TRUE : GL_FALSE;
1981 break;
Lingfeng Yangd0febe72018-05-17 22:36:52 -07001982 case GL_LIGHT_MODEL_TWO_SIDE:
1983 *params = IsLightModelTwoSided(&mGLES1State);
1984 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001985 default:
1986 UNREACHABLE();
1987 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04001988 }
1989}
1990
1991void State::getFloatv(GLenum pname, GLfloat *params)
1992{
1993 // Please note: DEPTH_CLEAR_VALUE is included in our internal getFloatv implementation
1994 // because it is stored as a float, despite the fact that the GL ES 2.0 spec names
1995 // GetIntegerv as its native query function. As it would require conversion in any
1996 // case, this should make no difference to the calling application.
1997 switch (pname)
1998 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001999 case GL_LINE_WIDTH:
2000 *params = mLineWidth;
2001 break;
2002 case GL_SAMPLE_COVERAGE_VALUE:
2003 *params = mSampleCoverageValue;
2004 break;
2005 case GL_DEPTH_CLEAR_VALUE:
2006 *params = mDepthClearValue;
2007 break;
2008 case GL_POLYGON_OFFSET_FACTOR:
2009 *params = mRasterizer.polygonOffsetFactor;
2010 break;
2011 case GL_POLYGON_OFFSET_UNITS:
2012 *params = mRasterizer.polygonOffsetUnits;
2013 break;
2014 case GL_DEPTH_RANGE:
2015 params[0] = mNearZ;
2016 params[1] = mFarZ;
2017 break;
2018 case GL_COLOR_CLEAR_VALUE:
2019 params[0] = mColorClearValue.red;
2020 params[1] = mColorClearValue.green;
2021 params[2] = mColorClearValue.blue;
2022 params[3] = mColorClearValue.alpha;
2023 break;
2024 case GL_BLEND_COLOR:
2025 params[0] = mBlendColor.red;
2026 params[1] = mBlendColor.green;
2027 params[2] = mBlendColor.blue;
2028 params[3] = mBlendColor.alpha;
2029 break;
2030 case GL_MULTISAMPLE_EXT:
2031 *params = static_cast<GLfloat>(mMultiSampling);
2032 break;
2033 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
2034 *params = static_cast<GLfloat>(mSampleAlphaToOne);
2035 break;
2036 case GL_COVERAGE_MODULATION_CHROMIUM:
2037 params[0] = static_cast<GLfloat>(mCoverageModulation);
2038 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -07002039 case GL_ALPHA_TEST_REF:
2040 *params = mGLES1State.mAlphaTestRef;
2041 break;
Lingfeng Yanga43994c2018-03-29 07:21:41 -07002042 case GL_CURRENT_COLOR:
2043 {
2044 const auto &color = mGLES1State.mCurrentColor;
2045 params[0] = color.red;
2046 params[1] = color.green;
2047 params[2] = color.blue;
2048 params[3] = color.alpha;
2049 break;
2050 }
Lingfeng Yang5a7e61b2018-03-29 16:50:32 -07002051 case GL_CURRENT_NORMAL:
2052 {
2053 const auto &normal = mGLES1State.mCurrentNormal;
2054 params[0] = normal[0];
2055 params[1] = normal[1];
2056 params[2] = normal[2];
2057 break;
2058 }
Lingfeng Yang038dd532018-03-29 17:31:52 -07002059 case GL_CURRENT_TEXTURE_COORDS:
2060 {
2061 const auto &texcoord = mGLES1State.mCurrentTextureCoords[mActiveSampler];
2062 params[0] = texcoord.s;
2063 params[1] = texcoord.t;
2064 params[2] = texcoord.r;
2065 params[3] = texcoord.q;
2066 break;
2067 }
Lingfeng Yang3a41af62018-04-09 07:28:56 -07002068 case GL_MODELVIEW_MATRIX:
2069 memcpy(params, mGLES1State.mModelviewMatrices.back().data(), 16 * sizeof(GLfloat));
2070 break;
2071 case GL_PROJECTION_MATRIX:
2072 memcpy(params, mGLES1State.mProjectionMatrices.back().data(), 16 * sizeof(GLfloat));
2073 break;
2074 case GL_TEXTURE_MATRIX:
2075 memcpy(params, mGLES1State.mTextureMatrices[mActiveSampler].back().data(),
2076 16 * sizeof(GLfloat));
2077 break;
Lingfeng Yangd0febe72018-05-17 22:36:52 -07002078 case GL_LIGHT_MODEL_AMBIENT:
2079 GetLightModelParameters(&mGLES1State, pname, params);
2080 break;
Lingfeng Yang7ba3f422018-06-01 09:43:04 -07002081 case GL_FOG_MODE:
2082 case GL_FOG_DENSITY:
2083 case GL_FOG_START:
2084 case GL_FOG_END:
2085 case GL_FOG_COLOR:
2086 GetFogParameters(&mGLES1State, pname, params);
2087 break;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -07002088 case GL_POINT_SIZE:
2089 GetPointSize(&mGLES1State, params);
2090 break;
2091 case GL_POINT_SIZE_MIN:
2092 case GL_POINT_SIZE_MAX:
2093 case GL_POINT_FADE_THRESHOLD_SIZE:
2094 case GL_POINT_DISTANCE_ATTENUATION:
2095 GetPointParameter(&mGLES1State, FromGLenum<PointParameter>(pname), params);
2096 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002097 default:
2098 UNREACHABLE();
2099 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002100 }
2101}
2102
Jamie Madille98b1b52018-03-08 09:47:23 -05002103Error State::getIntegerv(const Context *context, GLenum pname, GLint *params)
Shannon Woods53a94a82014-06-24 15:20:36 -04002104{
2105 if (pname >= GL_DRAW_BUFFER0_EXT && pname <= GL_DRAW_BUFFER15_EXT)
2106 {
2107 unsigned int colorAttachment = (pname - GL_DRAW_BUFFER0_EXT);
Shannon Woods2df6a602014-09-26 16:12:07 -04002108 ASSERT(colorAttachment < mMaxDrawBuffers);
Shannon Woods53a94a82014-06-24 15:20:36 -04002109 Framebuffer *framebuffer = mDrawFramebuffer;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002110 *params = framebuffer->getDrawBufferState(colorAttachment);
Jamie Madille98b1b52018-03-08 09:47:23 -05002111 return NoError();
Shannon Woods53a94a82014-06-24 15:20:36 -04002112 }
2113
2114 // Please note: DEPTH_CLEAR_VALUE is not included in our internal getIntegerv implementation
2115 // because it is stored as a float, despite the fact that the GL ES 2.0 spec names
2116 // GetIntegerv as its native query function. As it would require conversion in any
2117 // case, this should make no difference to the calling application. You may find it in
2118 // State::getFloatv.
2119 switch (pname)
2120 {
Corentin Wallez336129f2017-10-17 15:55:40 -04002121 case GL_ARRAY_BUFFER_BINDING:
2122 *params = mBoundBuffers[BufferBinding::Array].id();
2123 break;
2124 case GL_DRAW_INDIRECT_BUFFER_BINDING:
2125 *params = mBoundBuffers[BufferBinding::DrawIndirect].id();
2126 break;
2127 case GL_ELEMENT_ARRAY_BUFFER_BINDING:
2128 *params = getVertexArray()->getElementArrayBuffer().id();
2129 break;
Jamie Madill690c8eb2018-03-12 15:20:03 -04002130 case GL_DRAW_FRAMEBUFFER_BINDING:
2131 static_assert(GL_DRAW_FRAMEBUFFER_BINDING == GL_DRAW_FRAMEBUFFER_BINDING_ANGLE,
2132 "Enum mismatch");
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002133 *params = mDrawFramebuffer->id();
2134 break;
Jamie Madill690c8eb2018-03-12 15:20:03 -04002135 case GL_READ_FRAMEBUFFER_BINDING:
2136 static_assert(GL_READ_FRAMEBUFFER_BINDING == GL_READ_FRAMEBUFFER_BINDING_ANGLE,
2137 "Enum mismatch");
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002138 *params = mReadFramebuffer->id();
2139 break;
2140 case GL_RENDERBUFFER_BINDING:
2141 *params = mRenderbuffer.id();
2142 break;
2143 case GL_VERTEX_ARRAY_BINDING:
2144 *params = mVertexArray->id();
2145 break;
2146 case GL_CURRENT_PROGRAM:
2147 *params = mProgram ? mProgram->id() : 0;
2148 break;
2149 case GL_PACK_ALIGNMENT:
2150 *params = mPack.alignment;
2151 break;
2152 case GL_PACK_REVERSE_ROW_ORDER_ANGLE:
2153 *params = mPack.reverseRowOrder;
2154 break;
2155 case GL_PACK_ROW_LENGTH:
2156 *params = mPack.rowLength;
2157 break;
2158 case GL_PACK_SKIP_ROWS:
2159 *params = mPack.skipRows;
2160 break;
2161 case GL_PACK_SKIP_PIXELS:
2162 *params = mPack.skipPixels;
2163 break;
2164 case GL_UNPACK_ALIGNMENT:
2165 *params = mUnpack.alignment;
2166 break;
2167 case GL_UNPACK_ROW_LENGTH:
2168 *params = mUnpack.rowLength;
2169 break;
2170 case GL_UNPACK_IMAGE_HEIGHT:
2171 *params = mUnpack.imageHeight;
2172 break;
2173 case GL_UNPACK_SKIP_IMAGES:
2174 *params = mUnpack.skipImages;
2175 break;
2176 case GL_UNPACK_SKIP_ROWS:
2177 *params = mUnpack.skipRows;
2178 break;
2179 case GL_UNPACK_SKIP_PIXELS:
2180 *params = mUnpack.skipPixels;
2181 break;
2182 case GL_GENERATE_MIPMAP_HINT:
2183 *params = mGenerateMipmapHint;
2184 break;
2185 case GL_FRAGMENT_SHADER_DERIVATIVE_HINT_OES:
2186 *params = mFragmentShaderDerivativeHint;
2187 break;
2188 case GL_ACTIVE_TEXTURE:
2189 *params = (static_cast<GLint>(mActiveSampler) + GL_TEXTURE0);
2190 break;
2191 case GL_STENCIL_FUNC:
2192 *params = mDepthStencil.stencilFunc;
2193 break;
2194 case GL_STENCIL_REF:
2195 *params = mStencilRef;
2196 break;
2197 case GL_STENCIL_VALUE_MASK:
2198 *params = CastMaskValue(context, mDepthStencil.stencilMask);
2199 break;
2200 case GL_STENCIL_BACK_FUNC:
2201 *params = mDepthStencil.stencilBackFunc;
2202 break;
2203 case GL_STENCIL_BACK_REF:
2204 *params = mStencilBackRef;
2205 break;
2206 case GL_STENCIL_BACK_VALUE_MASK:
2207 *params = CastMaskValue(context, mDepthStencil.stencilBackMask);
2208 break;
2209 case GL_STENCIL_FAIL:
2210 *params = mDepthStencil.stencilFail;
2211 break;
2212 case GL_STENCIL_PASS_DEPTH_FAIL:
2213 *params = mDepthStencil.stencilPassDepthFail;
2214 break;
2215 case GL_STENCIL_PASS_DEPTH_PASS:
2216 *params = mDepthStencil.stencilPassDepthPass;
2217 break;
2218 case GL_STENCIL_BACK_FAIL:
2219 *params = mDepthStencil.stencilBackFail;
2220 break;
2221 case GL_STENCIL_BACK_PASS_DEPTH_FAIL:
2222 *params = mDepthStencil.stencilBackPassDepthFail;
2223 break;
2224 case GL_STENCIL_BACK_PASS_DEPTH_PASS:
2225 *params = mDepthStencil.stencilBackPassDepthPass;
2226 break;
2227 case GL_DEPTH_FUNC:
2228 *params = mDepthStencil.depthFunc;
2229 break;
2230 case GL_BLEND_SRC_RGB:
2231 *params = mBlend.sourceBlendRGB;
2232 break;
2233 case GL_BLEND_SRC_ALPHA:
2234 *params = mBlend.sourceBlendAlpha;
2235 break;
2236 case GL_BLEND_DST_RGB:
2237 *params = mBlend.destBlendRGB;
2238 break;
2239 case GL_BLEND_DST_ALPHA:
2240 *params = mBlend.destBlendAlpha;
2241 break;
2242 case GL_BLEND_EQUATION_RGB:
2243 *params = mBlend.blendEquationRGB;
2244 break;
2245 case GL_BLEND_EQUATION_ALPHA:
2246 *params = mBlend.blendEquationAlpha;
2247 break;
2248 case GL_STENCIL_WRITEMASK:
2249 *params = CastMaskValue(context, mDepthStencil.stencilWritemask);
2250 break;
2251 case GL_STENCIL_BACK_WRITEMASK:
2252 *params = CastMaskValue(context, mDepthStencil.stencilBackWritemask);
2253 break;
2254 case GL_STENCIL_CLEAR_VALUE:
2255 *params = mStencilClearValue;
2256 break;
2257 case GL_IMPLEMENTATION_COLOR_READ_TYPE:
Jamie Madill690c8eb2018-03-12 15:20:03 -04002258 ANGLE_TRY(mReadFramebuffer->getImplementationColorReadType(
2259 context, reinterpret_cast<GLenum *>(params)));
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002260 break;
2261 case GL_IMPLEMENTATION_COLOR_READ_FORMAT:
Jamie Madill690c8eb2018-03-12 15:20:03 -04002262 ANGLE_TRY(mReadFramebuffer->getImplementationColorReadFormat(
2263 context, reinterpret_cast<GLenum *>(params)));
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002264 break;
2265 case GL_SAMPLE_BUFFERS:
2266 case GL_SAMPLES:
Shannon Woods53a94a82014-06-24 15:20:36 -04002267 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002268 Framebuffer *framebuffer = mDrawFramebuffer;
Jamie Madill427064d2018-04-13 16:20:34 -04002269 if (framebuffer->isComplete(context))
Shannon Woods53a94a82014-06-24 15:20:36 -04002270 {
Jamie Madill427064d2018-04-13 16:20:34 -04002271 GLint samples = framebuffer->getSamples(context);
Shannon Woods53a94a82014-06-24 15:20:36 -04002272 switch (pname)
2273 {
Jamie Madilla0016b72017-07-14 14:30:46 -04002274 case GL_SAMPLE_BUFFERS:
Jamie Madille98b1b52018-03-08 09:47:23 -05002275 if (samples != 0)
Jamie Madilla0016b72017-07-14 14:30:46 -04002276 {
2277 *params = 1;
2278 }
2279 else
2280 {
2281 *params = 0;
2282 }
2283 break;
2284 case GL_SAMPLES:
Jamie Madille98b1b52018-03-08 09:47:23 -05002285 *params = samples;
Jamie Madilla0016b72017-07-14 14:30:46 -04002286 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002287 }
2288 }
2289 else
2290 {
2291 *params = 0;
2292 }
2293 }
2294 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002295 case GL_VIEWPORT:
2296 params[0] = mViewport.x;
2297 params[1] = mViewport.y;
2298 params[2] = mViewport.width;
2299 params[3] = mViewport.height;
2300 break;
2301 case GL_SCISSOR_BOX:
2302 params[0] = mScissor.x;
2303 params[1] = mScissor.y;
2304 params[2] = mScissor.width;
2305 params[3] = mScissor.height;
2306 break;
2307 case GL_CULL_FACE_MODE:
2308 *params = ToGLenum(mRasterizer.cullMode);
2309 break;
2310 case GL_FRONT_FACE:
2311 *params = mRasterizer.frontFace;
2312 break;
2313 case GL_RED_BITS:
2314 case GL_GREEN_BITS:
2315 case GL_BLUE_BITS:
2316 case GL_ALPHA_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002317 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002318 Framebuffer *framebuffer = getDrawFramebuffer();
2319 const FramebufferAttachment *colorbuffer = framebuffer->getFirstColorbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002320
2321 if (colorbuffer)
2322 {
2323 switch (pname)
2324 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002325 case GL_RED_BITS:
2326 *params = colorbuffer->getRedSize();
2327 break;
2328 case GL_GREEN_BITS:
2329 *params = colorbuffer->getGreenSize();
2330 break;
2331 case GL_BLUE_BITS:
2332 *params = colorbuffer->getBlueSize();
2333 break;
2334 case GL_ALPHA_BITS:
2335 *params = colorbuffer->getAlphaSize();
2336 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002337 }
2338 }
2339 else
2340 {
2341 *params = 0;
2342 }
2343 }
2344 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002345 case GL_DEPTH_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002346 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002347 const Framebuffer *framebuffer = getDrawFramebuffer();
2348 const FramebufferAttachment *depthbuffer = framebuffer->getDepthbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002349
2350 if (depthbuffer)
2351 {
2352 *params = depthbuffer->getDepthSize();
2353 }
2354 else
2355 {
2356 *params = 0;
2357 }
2358 }
2359 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002360 case GL_STENCIL_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002361 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002362 const Framebuffer *framebuffer = getDrawFramebuffer();
2363 const FramebufferAttachment *stencilbuffer = framebuffer->getStencilbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002364
2365 if (stencilbuffer)
2366 {
2367 *params = stencilbuffer->getStencilSize();
2368 }
2369 else
2370 {
2371 *params = 0;
2372 }
2373 }
2374 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002375 case GL_TEXTURE_BINDING_2D:
2376 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2377 *params =
2378 getSamplerTextureId(static_cast<unsigned int>(mActiveSampler), TextureType::_2D);
2379 break;
2380 case GL_TEXTURE_BINDING_RECTANGLE_ANGLE:
2381 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2382 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2383 TextureType::Rectangle);
2384 break;
2385 case GL_TEXTURE_BINDING_CUBE_MAP:
2386 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2387 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2388 TextureType::CubeMap);
2389 break;
2390 case GL_TEXTURE_BINDING_3D:
2391 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2392 *params =
2393 getSamplerTextureId(static_cast<unsigned int>(mActiveSampler), TextureType::_3D);
2394 break;
2395 case GL_TEXTURE_BINDING_2D_ARRAY:
2396 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2397 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2398 TextureType::_2DArray);
2399 break;
2400 case GL_TEXTURE_BINDING_2D_MULTISAMPLE:
2401 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2402 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2403 TextureType::_2DMultisample);
2404 break;
2405 case GL_TEXTURE_BINDING_EXTERNAL_OES:
2406 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2407 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2408 TextureType::External);
2409 break;
2410 case GL_UNIFORM_BUFFER_BINDING:
2411 *params = mBoundBuffers[BufferBinding::Uniform].id();
2412 break;
2413 case GL_TRANSFORM_FEEDBACK_BINDING:
2414 *params = mTransformFeedback.id();
2415 break;
2416 case GL_TRANSFORM_FEEDBACK_BUFFER_BINDING:
2417 *params = mBoundBuffers[BufferBinding::TransformFeedback].id();
2418 break;
2419 case GL_COPY_READ_BUFFER_BINDING:
2420 *params = mBoundBuffers[BufferBinding::CopyRead].id();
2421 break;
2422 case GL_COPY_WRITE_BUFFER_BINDING:
2423 *params = mBoundBuffers[BufferBinding::CopyWrite].id();
2424 break;
2425 case GL_PIXEL_PACK_BUFFER_BINDING:
2426 *params = mBoundBuffers[BufferBinding::PixelPack].id();
2427 break;
2428 case GL_PIXEL_UNPACK_BUFFER_BINDING:
2429 *params = mBoundBuffers[BufferBinding::PixelUnpack].id();
2430 break;
2431 case GL_READ_BUFFER:
2432 *params = mReadFramebuffer->getReadBufferState();
2433 break;
2434 case GL_SAMPLER_BINDING:
2435 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2436 *params = getSamplerId(static_cast<GLuint>(mActiveSampler));
2437 break;
2438 case GL_DEBUG_LOGGED_MESSAGES:
2439 *params = static_cast<GLint>(mDebug.getMessageCount());
2440 break;
2441 case GL_DEBUG_NEXT_LOGGED_MESSAGE_LENGTH:
2442 *params = static_cast<GLint>(mDebug.getNextMessageLength());
2443 break;
2444 case GL_DEBUG_GROUP_STACK_DEPTH:
2445 *params = static_cast<GLint>(mDebug.getGroupStackDepth());
2446 break;
2447 case GL_MULTISAMPLE_EXT:
2448 *params = static_cast<GLint>(mMultiSampling);
2449 break;
2450 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
2451 *params = static_cast<GLint>(mSampleAlphaToOne);
2452 break;
2453 case GL_COVERAGE_MODULATION_CHROMIUM:
2454 *params = static_cast<GLint>(mCoverageModulation);
2455 break;
2456 case GL_ATOMIC_COUNTER_BUFFER_BINDING:
2457 *params = mBoundBuffers[BufferBinding::AtomicCounter].id();
2458 break;
2459 case GL_SHADER_STORAGE_BUFFER_BINDING:
2460 *params = mBoundBuffers[BufferBinding::ShaderStorage].id();
2461 break;
2462 case GL_DISPATCH_INDIRECT_BUFFER_BINDING:
2463 *params = mBoundBuffers[BufferBinding::DispatchIndirect].id();
2464 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -07002465 case GL_ALPHA_TEST_FUNC:
2466 *params = ToGLenum(mGLES1State.mAlphaTestFunc);
2467 break;
Lingfeng Yang96310cd2018-03-28 11:56:28 -07002468 case GL_CLIENT_ACTIVE_TEXTURE:
2469 *params = mGLES1State.mClientActiveTexture + GL_TEXTURE0;
2470 break;
Lingfeng Yangd2488ab2018-04-04 09:25:48 -07002471 case GL_MATRIX_MODE:
2472 *params = ToGLenum(mGLES1State.mMatrixMode);
2473 break;
Lingfeng Yanga0cfa872018-05-30 21:12:17 -07002474 case GL_SHADE_MODEL:
2475 *params = ToGLenum(mGLES1State.mShadeModel);
2476 break;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -07002477 case GL_MODELVIEW_STACK_DEPTH:
2478 case GL_PROJECTION_STACK_DEPTH:
2479 case GL_TEXTURE_STACK_DEPTH:
2480 *params = mGLES1State.getCurrentMatrixStackDepth(pname);
2481 break;
2482 case GL_LOGIC_OP_MODE:
2483 *params = ToGLenum(mGLES1State.mLogicOp);
2484 break;
2485 case GL_BLEND_SRC:
2486 *params = mBlend.sourceBlendRGB;
2487 break;
2488 case GL_BLEND_DST:
2489 *params = mBlend.destBlendRGB;
2490 break;
2491 case GL_PERSPECTIVE_CORRECTION_HINT:
2492 case GL_POINT_SMOOTH_HINT:
2493 case GL_LINE_SMOOTH_HINT:
2494 case GL_FOG_HINT:
2495 *params = mGLES1State.getHint(pname);
2496 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002497 default:
2498 UNREACHABLE();
2499 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002500 }
Jamie Madille98b1b52018-03-08 09:47:23 -05002501
2502 return NoError();
Shannon Woods53a94a82014-06-24 15:20:36 -04002503}
2504
Lingfeng Yangabb09f12018-04-16 10:43:53 -07002505void State::getPointerv(const Context *context, GLenum pname, void **params) const
Geoff Lang70d0f492015-12-10 17:45:46 -05002506{
2507 switch (pname)
2508 {
2509 case GL_DEBUG_CALLBACK_FUNCTION:
2510 *params = reinterpret_cast<void *>(mDebug.getCallback());
2511 break;
2512 case GL_DEBUG_CALLBACK_USER_PARAM:
2513 *params = const_cast<void *>(mDebug.getUserParam());
2514 break;
Lingfeng Yangabb09f12018-04-16 10:43:53 -07002515 case GL_VERTEX_ARRAY_POINTER:
2516 case GL_NORMAL_ARRAY_POINTER:
2517 case GL_COLOR_ARRAY_POINTER:
2518 case GL_TEXTURE_COORD_ARRAY_POINTER:
2519 case GL_POINT_SIZE_ARRAY_POINTER_OES:
2520 QueryVertexAttribPointerv(getVertexArray()->getVertexAttribute(
2521 context->vertexArrayIndex(ParamToVertexArrayType(pname))),
2522 GL_VERTEX_ATTRIB_ARRAY_POINTER, params);
2523 return;
Geoff Lang70d0f492015-12-10 17:45:46 -05002524 default:
2525 UNREACHABLE();
2526 break;
2527 }
2528}
2529
Martin Radev66fb8202016-07-28 11:45:20 +03002530void State::getIntegeri_v(GLenum target, GLuint index, GLint *data)
Shannon Woods53a94a82014-06-24 15:20:36 -04002531{
2532 switch (target)
2533 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002534 case GL_TRANSFORM_FEEDBACK_BUFFER_BINDING:
2535 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2536 *data = mTransformFeedback->getIndexedBuffer(index).id();
2537 break;
2538 case GL_UNIFORM_BUFFER_BINDING:
2539 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2540 *data = mUniformBuffers[index].id();
2541 break;
2542 case GL_ATOMIC_COUNTER_BUFFER_BINDING:
2543 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2544 *data = mAtomicCounterBuffers[index].id();
2545 break;
2546 case GL_SHADER_STORAGE_BUFFER_BINDING:
2547 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2548 *data = mShaderStorageBuffers[index].id();
2549 break;
2550 case GL_VERTEX_BINDING_BUFFER:
2551 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2552 *data = mVertexArray->getVertexBinding(index).getBuffer().id();
2553 break;
2554 case GL_VERTEX_BINDING_DIVISOR:
2555 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2556 *data = mVertexArray->getVertexBinding(index).getDivisor();
2557 break;
2558 case GL_VERTEX_BINDING_OFFSET:
2559 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2560 *data = static_cast<GLuint>(mVertexArray->getVertexBinding(index).getOffset());
2561 break;
2562 case GL_VERTEX_BINDING_STRIDE:
2563 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2564 *data = mVertexArray->getVertexBinding(index).getStride();
2565 break;
2566 case GL_SAMPLE_MASK_VALUE:
2567 ASSERT(static_cast<size_t>(index) < mSampleMaskValues.size());
2568 *data = mSampleMaskValues[index];
2569 break;
2570 case GL_IMAGE_BINDING_NAME:
2571 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2572 *data = mImageUnits[index].texture.id();
2573 break;
2574 case GL_IMAGE_BINDING_LEVEL:
2575 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2576 *data = mImageUnits[index].level;
2577 break;
2578 case GL_IMAGE_BINDING_LAYER:
2579 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2580 *data = mImageUnits[index].layer;
2581 break;
2582 case GL_IMAGE_BINDING_ACCESS:
2583 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2584 *data = mImageUnits[index].access;
2585 break;
2586 case GL_IMAGE_BINDING_FORMAT:
2587 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2588 *data = mImageUnits[index].format;
2589 break;
2590 default:
2591 UNREACHABLE();
2592 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002593 }
Shannon Woods53a94a82014-06-24 15:20:36 -04002594}
2595
Martin Radev66fb8202016-07-28 11:45:20 +03002596void State::getInteger64i_v(GLenum target, GLuint index, GLint64 *data)
Shannon Woods53a94a82014-06-24 15:20:36 -04002597{
2598 switch (target)
2599 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002600 case GL_TRANSFORM_FEEDBACK_BUFFER_START:
2601 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2602 *data = mTransformFeedback->getIndexedBuffer(index).getOffset();
2603 break;
2604 case GL_TRANSFORM_FEEDBACK_BUFFER_SIZE:
2605 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2606 *data = mTransformFeedback->getIndexedBuffer(index).getSize();
2607 break;
2608 case GL_UNIFORM_BUFFER_START:
2609 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2610 *data = mUniformBuffers[index].getOffset();
2611 break;
2612 case GL_UNIFORM_BUFFER_SIZE:
2613 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2614 *data = mUniformBuffers[index].getSize();
2615 break;
2616 case GL_ATOMIC_COUNTER_BUFFER_START:
2617 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2618 *data = mAtomicCounterBuffers[index].getOffset();
2619 break;
2620 case GL_ATOMIC_COUNTER_BUFFER_SIZE:
2621 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2622 *data = mAtomicCounterBuffers[index].getSize();
2623 break;
2624 case GL_SHADER_STORAGE_BUFFER_START:
2625 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2626 *data = mShaderStorageBuffers[index].getOffset();
2627 break;
2628 case GL_SHADER_STORAGE_BUFFER_SIZE:
2629 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2630 *data = mShaderStorageBuffers[index].getSize();
2631 break;
2632 default:
2633 UNREACHABLE();
2634 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002635 }
Martin Radev66fb8202016-07-28 11:45:20 +03002636}
Shannon Woods53a94a82014-06-24 15:20:36 -04002637
Martin Radev66fb8202016-07-28 11:45:20 +03002638void State::getBooleani_v(GLenum target, GLuint index, GLboolean *data)
2639{
Xinghua Cao9c8e1a32017-12-06 17:59:58 +08002640 switch (target)
2641 {
2642 case GL_IMAGE_BINDING_LAYERED:
2643 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2644 *data = mImageUnits[index].layered;
2645 break;
2646 default:
2647 UNREACHABLE();
2648 break;
2649 }
Shannon Woods53a94a82014-06-24 15:20:36 -04002650}
2651
Jamie Madillbc918e72018-03-08 09:47:21 -05002652Error State::syncDirtyObjects(const Context *context, const DirtyObjects &bitset)
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002653{
Jiajia Qin5ae6ee42018-03-06 17:39:42 +08002654 const DirtyObjects &dirtyObjects = mDirtyObjects & bitset;
2655 for (auto dirtyObject : dirtyObjects)
Jamie Madillc9d442d2016-01-20 11:17:24 -05002656 {
2657 switch (dirtyObject)
2658 {
2659 case DIRTY_OBJECT_READ_FRAMEBUFFER:
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002660 ASSERT(mReadFramebuffer);
Jamie Madill19fa1c62018-03-08 09:47:21 -05002661 ANGLE_TRY(mReadFramebuffer->syncState(context));
Jamie Madillc9d442d2016-01-20 11:17:24 -05002662 break;
2663 case DIRTY_OBJECT_DRAW_FRAMEBUFFER:
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002664 ASSERT(mDrawFramebuffer);
Jamie Madill19fa1c62018-03-08 09:47:21 -05002665 ANGLE_TRY(mDrawFramebuffer->syncState(context));
Jamie Madillc9d442d2016-01-20 11:17:24 -05002666 break;
2667 case DIRTY_OBJECT_VERTEX_ARRAY:
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002668 ASSERT(mVertexArray);
Frank Henigman0af5b862018-03-27 20:19:33 -04002669 ANGLE_TRY(mVertexArray->syncState(context));
Jamie Madillc9d442d2016-01-20 11:17:24 -05002670 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002671 case DIRTY_OBJECT_PROGRAM_TEXTURES:
Luc Ferron4bba74f2018-04-19 14:40:45 -04002672 ANGLE_TRY(syncProgramTextures(context));
Jamie Madill81c2e252017-09-09 23:32:46 -04002673 break;
Jamie Madill70aeda42018-08-20 12:17:40 -04002674 case DIRTY_OBJECT_PROGRAM:
2675 ANGLE_TRY(mProgram->syncState(context));
2676 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002677
Jamie Madillc9d442d2016-01-20 11:17:24 -05002678 default:
2679 UNREACHABLE();
2680 break;
2681 }
2682 }
2683
Jiajia Qin5ae6ee42018-03-06 17:39:42 +08002684 mDirtyObjects &= ~dirtyObjects;
Jamie Madillbc918e72018-03-08 09:47:21 -05002685 return NoError();
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002686}
2687
Luc Ferron4bba74f2018-04-19 14:40:45 -04002688Error State::syncProgramTextures(const Context *context)
Jamie Madill81c2e252017-09-09 23:32:46 -04002689{
Jamie Madill81c2e252017-09-09 23:32:46 -04002690 // TODO(jmadill): Fine-grained updates.
2691 if (!mProgram)
2692 {
Luc Ferron4bba74f2018-04-19 14:40:45 -04002693 return NoError();
Jamie Madill81c2e252017-09-09 23:32:46 -04002694 }
2695
2696 ASSERT(mDirtyObjects[DIRTY_OBJECT_PROGRAM_TEXTURES]);
2697 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
2698
Jamie Madill0f80ed82017-09-19 00:24:56 -04002699 ActiveTextureMask newActiveTextures;
2700
Geoff Lange51ba632017-11-21 11:45:25 -05002701 // Initialize to the 'Initialized' state and set to 'MayNeedInit' if any texture is not
2702 // initialized.
2703 mCachedTexturesInitState = InitState::Initialized;
2704
Jamie Madill7e4eff12018-08-08 15:49:26 -04002705 const ActiveTextureMask &activeTextures = mProgram->getActiveSamplersMask();
2706 const ActiveTextureArray<TextureType> &textureTypes = mProgram->getActiveSamplerTypes();
2707
2708 for (size_t textureUnitIndex : activeTextures)
Jamie Madill81c2e252017-09-09 23:32:46 -04002709 {
Jamie Madill7e4eff12018-08-08 15:49:26 -04002710 TextureType textureType = textureTypes[textureUnitIndex];
Jamie Madill81c2e252017-09-09 23:32:46 -04002711
jchen1090f466a2018-08-13 15:05:25 +08002712 Texture *texture =
2713 getSamplerTexture(static_cast<unsigned int>(textureUnitIndex), textureType);
2714 Sampler *sampler = getSampler(static_cast<GLuint>(textureUnitIndex));
Jamie Madill4787d702018-08-08 15:49:26 -04002715 ASSERT(static_cast<size_t>(textureUnitIndex) < mActiveTexturesCache.size());
Jamie Madill7e4eff12018-08-08 15:49:26 -04002716 ASSERT(static_cast<size_t>(textureUnitIndex) < newActiveTextures.size());
2717
2718 ASSERT(texture);
2719
2720 // Mark the texture binding bit as dirty if the texture completeness changes.
2721 // TODO(jmadill): Use specific dirty bit for completeness change.
2722 if (texture->isSamplerComplete(context, sampler) &&
2723 !mDrawFramebuffer->hasTextureAttachment(texture))
Jamie Madill81c2e252017-09-09 23:32:46 -04002724 {
Jamie Madill7e4eff12018-08-08 15:49:26 -04002725 ANGLE_TRY(texture->syncState(context));
Jamie Madill4787d702018-08-08 15:49:26 -04002726 mActiveTexturesCache[textureUnitIndex] = texture;
Jamie Madill7e4eff12018-08-08 15:49:26 -04002727 }
2728 else
2729 {
Jamie Madill4787d702018-08-08 15:49:26 -04002730 mActiveTexturesCache[textureUnitIndex] = nullptr;
Jamie Madill7e4eff12018-08-08 15:49:26 -04002731 }
Jamie Madill81c2e252017-09-09 23:32:46 -04002732
Jamie Madill7e4eff12018-08-08 15:49:26 -04002733 // Bind the texture unconditionally, to recieve completeness change notifications.
2734 mCompleteTextureBindings[textureUnitIndex].bind(texture->getSubject());
2735 newActiveTextures.set(textureUnitIndex);
Jamie Madill81c2e252017-09-09 23:32:46 -04002736
Jamie Madill7e4eff12018-08-08 15:49:26 -04002737 if (sampler != nullptr)
2738 {
2739 sampler->syncState(context);
2740 }
Jamie Madill42975642017-10-12 12:31:51 -04002741
Jamie Madill7e4eff12018-08-08 15:49:26 -04002742 if (texture->initState() == InitState::MayNeedInit)
2743 {
2744 mCachedTexturesInitState = InitState::MayNeedInit;
Jamie Madill81c2e252017-09-09 23:32:46 -04002745 }
2746 }
Jamie Madill0f80ed82017-09-19 00:24:56 -04002747
2748 // Unset now missing textures.
Jamie Madill7e4eff12018-08-08 15:49:26 -04002749 ActiveTextureMask negativeMask = activeTextures & ~newActiveTextures;
Jamie Madill0f80ed82017-09-19 00:24:56 -04002750 if (negativeMask.any())
2751 {
2752 for (auto textureIndex : negativeMask)
2753 {
2754 mCompleteTextureBindings[textureIndex].reset();
Jamie Madill4787d702018-08-08 15:49:26 -04002755 mActiveTexturesCache[textureIndex] = nullptr;
Jamie Madill0f80ed82017-09-19 00:24:56 -04002756 }
2757 }
Luc Ferron4bba74f2018-04-19 14:40:45 -04002758
2759 return NoError();
Jamie Madill81c2e252017-09-09 23:32:46 -04002760}
2761
Jamie Madillbc918e72018-03-08 09:47:21 -05002762Error State::syncDirtyObject(const Context *context, GLenum target)
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002763{
2764 DirtyObjects localSet;
2765
2766 switch (target)
2767 {
2768 case GL_READ_FRAMEBUFFER:
2769 localSet.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2770 break;
2771 case GL_DRAW_FRAMEBUFFER:
2772 localSet.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2773 break;
2774 case GL_FRAMEBUFFER:
2775 localSet.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2776 localSet.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2777 break;
2778 case GL_VERTEX_ARRAY:
2779 localSet.set(DIRTY_OBJECT_VERTEX_ARRAY);
2780 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002781 case GL_TEXTURE:
2782 case GL_SAMPLER:
Jamie Madill70aeda42018-08-20 12:17:40 -04002783 localSet.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
2784 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002785 case GL_PROGRAM:
2786 localSet.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Jamie Madill70aeda42018-08-20 12:17:40 -04002787 localSet.set(DIRTY_OBJECT_PROGRAM);
Jamie Madill81c2e252017-09-09 23:32:46 -04002788 break;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002789 }
2790
Jamie Madillbc918e72018-03-08 09:47:21 -05002791 return syncDirtyObjects(context, localSet);
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002792}
2793
2794void State::setObjectDirty(GLenum target)
2795{
2796 switch (target)
2797 {
2798 case GL_READ_FRAMEBUFFER:
2799 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2800 break;
2801 case GL_DRAW_FRAMEBUFFER:
2802 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2803 break;
2804 case GL_FRAMEBUFFER:
2805 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2806 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2807 break;
2808 case GL_VERTEX_ARRAY:
2809 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
2810 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002811 case GL_TEXTURE:
2812 case GL_SAMPLER:
Jamie Madill70aeda42018-08-20 12:17:40 -04002813 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
2814 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
2815 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002816 case GL_PROGRAM:
2817 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Jamie Madill70aeda42018-08-20 12:17:40 -04002818 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM);
Jamie Madill81c2e252017-09-09 23:32:46 -04002819 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
2820 break;
Jamie Madilla779b612017-07-24 11:46:05 -04002821 }
2822}
2823
2824void State::onProgramExecutableChange(Program *program)
2825{
2826 // OpenGL Spec:
2827 // "If LinkProgram or ProgramBinary successfully re-links a program object
2828 // that was already in use as a result of a previous call to UseProgram, then the
2829 // generated executable code will be installed as part of the current rendering state."
2830 if (program->isLinked() && mProgram == program)
2831 {
2832 mDirtyBits.set(DIRTY_BIT_PROGRAM_EXECUTABLE);
Jamie Madill81c2e252017-09-09 23:32:46 -04002833 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Jamie Madill70aeda42018-08-20 12:17:40 -04002834 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM);
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002835 }
Shannon Woods53a94a82014-06-24 15:20:36 -04002836}
Jamie Madillc9d442d2016-01-20 11:17:24 -05002837
Xinghua Cao65ec0b22017-03-28 16:10:52 +08002838void State::setImageUnit(const Context *context,
2839 GLuint unit,
2840 Texture *texture,
2841 GLint level,
2842 GLboolean layered,
2843 GLint layer,
2844 GLenum access,
2845 GLenum format)
2846{
2847 mImageUnits[unit].texture.set(context, texture);
2848 mImageUnits[unit].level = level;
2849 mImageUnits[unit].layered = layered;
2850 mImageUnits[unit].layer = layer;
2851 mImageUnits[unit].access = access;
2852 mImageUnits[unit].format = format;
2853}
2854
2855const ImageUnit &State::getImageUnit(GLuint unit) const
2856{
2857 return mImageUnits[unit];
2858}
2859
Jamie Madill81c2e252017-09-09 23:32:46 -04002860// Handle a dirty texture event.
Jamie Madill6c43a012018-08-08 15:49:27 -04002861void State::onActiveTextureStateChange(size_t textureIndex)
Jamie Madill81c2e252017-09-09 23:32:46 -04002862{
2863 // Conservatively assume all textures are dirty.
2864 // TODO(jmadill): More fine-grained update.
2865 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Geoff Lange51ba632017-11-21 11:45:25 -05002866
Jamie Madill6c43a012018-08-08 15:49:27 -04002867 if (!mActiveTexturesCache[textureIndex] ||
2868 mActiveTexturesCache[textureIndex]->initState() == InitState::MayNeedInit)
Geoff Lange51ba632017-11-21 11:45:25 -05002869 {
2870 mCachedTexturesInitState = InitState::MayNeedInit;
2871 }
Jamie Madill81c2e252017-09-09 23:32:46 -04002872}
2873
Jamie Madill6d32cef2018-08-14 02:34:28 -04002874void State::onUniformBufferStateChange(size_t uniformBufferIndex)
2875{
2876 // This could be represented by a different dirty bit. Using the same one keeps it simple.
2877 mDirtyBits.set(DIRTY_BIT_UNIFORM_BUFFER_BINDINGS);
2878}
2879
Jamie Madill05b35b22017-10-03 09:01:44 -04002880Error State::clearUnclearedActiveTextures(const Context *context)
2881{
Jamie Madilla59fc192017-11-02 12:57:58 -04002882 ASSERT(mRobustResourceInit);
Jamie Madill05b35b22017-10-03 09:01:44 -04002883
Geoff Lange51ba632017-11-21 11:45:25 -05002884 if (mCachedTexturesInitState == InitState::Initialized)
2885 {
2886 return NoError();
2887 }
2888
Geoff Lang9bf86f02018-07-26 11:46:34 -04002889 ASSERT(!mDirtyObjects[DIRTY_OBJECT_PROGRAM_TEXTURES]);
Geoff Langd4fff502017-09-22 11:28:28 -04002890
Jamie Madill7e4eff12018-08-08 15:49:26 -04002891 if (!mProgram)
2892 return NoError();
2893
2894 for (auto textureIndex : mProgram->getActiveSamplersMask())
Jamie Madill05b35b22017-10-03 09:01:44 -04002895 {
Jamie Madill4787d702018-08-08 15:49:26 -04002896 Texture *texture = mActiveTexturesCache[textureIndex];
Jamie Madill05b35b22017-10-03 09:01:44 -04002897 if (texture)
2898 {
2899 ANGLE_TRY(texture->ensureInitialized(context));
2900 }
2901 }
Jamie Madilla59fc192017-11-02 12:57:58 -04002902
Geoff Lange51ba632017-11-21 11:45:25 -05002903 mCachedTexturesInitState = InitState::Initialized;
2904
Jamie Madill05b35b22017-10-03 09:01:44 -04002905 return NoError();
2906}
2907
Jamie Madillc67323a2017-11-02 23:11:41 -04002908AttributesMask State::getAndResetDirtyCurrentValues() const
2909{
2910 AttributesMask retVal = mDirtyCurrentValues;
2911 mDirtyCurrentValues.reset();
2912 return retVal;
2913}
2914
James Darpiniane8a93c62018-01-04 18:02:24 -08002915bool State::isCurrentTransformFeedback(const TransformFeedback *tf) const
2916{
2917 return tf == mTransformFeedback.get();
2918}
Jamie Madillc9d442d2016-01-20 11:17:24 -05002919} // namespace gl