blob: 0a0a55a737b1595c4426795f462d4afd8edb6e83 [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),
Qin Jiajia47f6dd02018-08-10 13:36:32 +0800135 mCachedImageTexturesInitState(InitState::MayNeedInit),
Sami Väisänen74c23472016-05-09 17:30:30 +0300136 mPrimitiveRestart(false),
Geoff Lang4fb8a8b2018-06-01 16:47:57 -0400137 mDebug(debug),
Sami Väisänen74c23472016-05-09 17:30:30 +0300138 mMultiSampling(false),
Geoff Lang1d2c41d2016-10-19 16:14:46 -0700139 mSampleAlphaToOne(false),
Jamie Madille08a1d32017-03-07 17:24:06 -0500140 mFramebufferSRGB(true),
Geoff Lang4fb8a8b2018-06-01 16:47:57 -0400141 mRobustResourceInit(robustResourceInit),
jchen1082af6202018-06-22 10:59:52 +0800142 mProgramBinaryCacheEnabled(programBinaryCacheEnabled),
143 mMaxShaderCompilerThreads(std::numeric_limits<GLuint>::max())
Shannon Woods53a94a82014-06-24 15:20:36 -0400144{
Geoff Lang76b10c92014-09-05 16:28:14 -0400145}
146
Lingfeng Yang13b708f2018-03-21 12:14:10 -0700147State::~State()
148{
149}
Geoff Lang76b10c92014-09-05 16:28:14 -0400150
Jamie Madill6c43a012018-08-08 15:49:27 -0400151void State::initialize(Context *context)
Geoff Lang76b10c92014-09-05 16:28:14 -0400152{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700153 const Caps &caps = context->getCaps();
154 const Extensions &extensions = context->getExtensions();
Geoff Lang4751aab2017-10-30 15:14:52 -0400155 const Extensions &nativeExtensions = context->getImplementation()->getNativeExtensions();
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700156 const Version &clientVersion = context->getClientVersion();
Jamie Madill4928b7c2017-06-20 12:57:39 -0400157
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700158 mMaxDrawBuffers = caps.maxDrawBuffers;
Shannon Woods2df6a602014-09-26 16:12:07 -0400159 mMaxCombinedTextureImageUnits = caps.maxCombinedTextureImageUnits;
Shannon Woods53a94a82014-06-24 15:20:36 -0400160
Jamie Madillf75ab352015-03-16 10:46:52 -0400161 setColorClearValue(0.0f, 0.0f, 0.0f, 0.0f);
Shannon Woods53a94a82014-06-24 15:20:36 -0400162
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700163 mDepthClearValue = 1.0f;
Shannon Woods53a94a82014-06-24 15:20:36 -0400164 mStencilClearValue = 0;
165
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700166 mScissorTest = false;
167 mScissor.x = 0;
168 mScissor.y = 0;
169 mScissor.width = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400170 mScissor.height = 0;
171
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700172 mBlendColor.red = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400173 mBlendColor.green = 0;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700174 mBlendColor.blue = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400175 mBlendColor.alpha = 0;
176
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700177 mStencilRef = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400178 mStencilBackRef = 0;
179
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700180 mSampleCoverage = false;
181 mSampleCoverageValue = 1.0f;
Shannon Woods53a94a82014-06-24 15:20:36 -0400182 mSampleCoverageInvert = false;
Jiawei Shaodb342272017-09-27 10:21:45 +0800183
184 mMaxSampleMaskWords = caps.maxSampleMaskWords;
185 mSampleMask = false;
186 mSampleMaskValues.fill(~GLbitfield(0));
187
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700188 mGenerateMipmapHint = GL_DONT_CARE;
Shannon Woods53a94a82014-06-24 15:20:36 -0400189 mFragmentShaderDerivativeHint = GL_DONT_CARE;
190
191 mLineWidth = 1.0f;
192
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700193 mViewport.x = 0;
194 mViewport.y = 0;
195 mViewport.width = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400196 mViewport.height = 0;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700197 mNearZ = 0.0f;
198 mFarZ = 1.0f;
Shannon Woods53a94a82014-06-24 15:20:36 -0400199
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700200 mBlend.colorMaskRed = true;
Shannon Woods53a94a82014-06-24 15:20:36 -0400201 mBlend.colorMaskGreen = true;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700202 mBlend.colorMaskBlue = true;
Shannon Woods53a94a82014-06-24 15:20:36 -0400203 mBlend.colorMaskAlpha = true;
204
Geoff Lang76b10c92014-09-05 16:28:14 -0400205 mActiveSampler = 0;
206
Shannon Woods23e05002014-09-22 19:07:27 -0400207 mVertexAttribCurrentValues.resize(caps.maxVertexAttributes);
Shannon Woods53a94a82014-06-24 15:20:36 -0400208
Brandon Jonesc405ae72017-12-06 14:15:03 -0800209 // Set all indexes in state attributes type mask to float (default)
210 for (int i = 0; i < MAX_VERTEX_ATTRIBS; i++)
211 {
212 mCurrentValuesTypeMask.setIndex(GL_FLOAT, i);
213 }
214
Geoff Lang4dc3af02016-11-18 14:09:27 -0500215 mUniformBuffers.resize(caps.maxUniformBufferBindings);
Shannon Woodsf3acaf92014-09-23 18:07:11 -0400216
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800217 mSamplerTextures[TextureType::_2D].resize(caps.maxCombinedTextureImageUnits);
218 mSamplerTextures[TextureType::CubeMap].resize(caps.maxCombinedTextureImageUnits);
Geoff Langeb66a6e2016-10-31 13:06:12 -0400219 if (clientVersion >= Version(3, 0))
Shannon Woods53a94a82014-06-24 15:20:36 -0400220 {
Geoff Lang76b10c92014-09-05 16:28:14 -0400221 // TODO: These could also be enabled via extension
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800222 mSamplerTextures[TextureType::_2DArray].resize(caps.maxCombinedTextureImageUnits);
223 mSamplerTextures[TextureType::_3D].resize(caps.maxCombinedTextureImageUnits);
Shannon Woods53a94a82014-06-24 15:20:36 -0400224 }
Geoff Lang3b573612016-10-31 14:08:10 -0400225 if (clientVersion >= Version(3, 1))
226 {
Olli Etuahod310a432018-08-24 15:40:23 +0300227 // TODO(http://anglebug.com/2775): These could also be enabled via extension
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800228 mSamplerTextures[TextureType::_2DMultisample].resize(caps.maxCombinedTextureImageUnits);
Olli Etuahod310a432018-08-24 15:40:23 +0300229 mSamplerTextures[TextureType::_2DMultisampleArray].resize(
230 caps.maxCombinedTextureImageUnits);
Jiajia Qin6eafb042016-12-27 17:04:07 +0800231
232 mAtomicCounterBuffers.resize(caps.maxAtomicCounterBufferBindings);
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800233 mShaderStorageBuffers.resize(caps.maxShaderStorageBufferBindings);
Xinghua Cao65ec0b22017-03-28 16:10:52 +0800234 mImageUnits.resize(caps.maxImageUnits);
Geoff Lang3b573612016-10-31 14:08:10 -0400235 }
Geoff Lang4751aab2017-10-30 15:14:52 -0400236 if (nativeExtensions.textureRectangle)
Corentin Wallez13c0dd42017-07-04 18:27:01 -0400237 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800238 mSamplerTextures[TextureType::Rectangle].resize(caps.maxCombinedTextureImageUnits);
Corentin Wallez13c0dd42017-07-04 18:27:01 -0400239 }
Geoff Lang4751aab2017-10-30 15:14:52 -0400240 if (nativeExtensions.eglImageExternal || nativeExtensions.eglStreamConsumerExternal)
Ian Ewellbda75592016-04-18 17:25:54 -0400241 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800242 mSamplerTextures[TextureType::External].resize(caps.maxCombinedTextureImageUnits);
Ian Ewellbda75592016-04-18 17:25:54 -0400243 }
Jamie Madill81c2e252017-09-09 23:32:46 -0400244 mCompleteTextureBindings.reserve(caps.maxCombinedTextureImageUnits);
Geoff Lange51ba632017-11-21 11:45:25 -0500245 mCachedTexturesInitState = InitState::MayNeedInit;
Qin Jiajia47f6dd02018-08-10 13:36:32 +0800246 mCachedImageTexturesInitState = InitState::MayNeedInit;
Jamie Madill81c2e252017-09-09 23:32:46 -0400247 for (uint32_t textureIndex = 0; textureIndex < caps.maxCombinedTextureImageUnits;
248 ++textureIndex)
249 {
Jamie Madill6c43a012018-08-08 15:49:27 -0400250 mCompleteTextureBindings.emplace_back(context, textureIndex);
Jamie Madill81c2e252017-09-09 23:32:46 -0400251 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400252
Geoff Lang76b10c92014-09-05 16:28:14 -0400253 mSamplers.resize(caps.maxCombinedTextureImageUnits);
Shannon Woods53a94a82014-06-24 15:20:36 -0400254
Corentin Wallezad3ae902018-03-09 13:40:42 -0500255 for (QueryType type : angle::AllEnums<QueryType>())
256 {
257 mActiveQueries[type].set(context, nullptr);
258 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400259
Ian Ewell3ffd78b2016-01-22 16:09:42 -0500260 mProgram = nullptr;
Shannon Woods53a94a82014-06-24 15:20:36 -0400261
Ian Ewell3ffd78b2016-01-22 16:09:42 -0500262 mReadFramebuffer = nullptr;
263 mDrawFramebuffer = nullptr;
Jamie Madillb4b53c52015-02-03 15:22:48 -0500264
265 mPrimitiveRestart = false;
Geoff Lang70d0f492015-12-10 17:45:46 -0500266
Geoff Lang70d0f492015-12-10 17:45:46 -0500267 mDebug.setMaxLoggedMessages(extensions.maxDebugLoggedMessages);
Sami Väisänen74c23472016-05-09 17:30:30 +0300268
Geoff Lang488130e2017-09-27 13:53:11 -0400269 mMultiSampling = true;
270 mSampleAlphaToOne = false;
Sami Väisänena797e062016-05-12 15:23:40 +0300271
272 mCoverageModulation = GL_NONE;
Sami Väisänene45e53b2016-05-25 10:36:04 +0300273
274 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixProj);
275 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixMV);
276 mPathStencilFunc = GL_ALWAYS;
277 mPathStencilRef = 0;
278 mPathStencilMask = std::numeric_limits<GLuint>::max();
Jamie Madille08a1d32017-03-07 17:24:06 -0500279
Lingfeng Yangdbb9c532018-02-25 19:58:24 -0800280 // GLES1 emulation: Initialize state for GLES1 if version
281 // applies
282 if (clientVersion < Version(2, 0))
283 {
Lingfeng Yange547aac2018-04-05 09:39:20 -0700284 mGLES1State.initialize(context, this);
Lingfeng Yangdbb9c532018-02-25 19:58:24 -0800285 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400286}
287
Jamie Madill6c1f6712017-02-14 19:08:04 -0500288void State::reset(const Context *context)
Shannon Woods53a94a82014-06-24 15:20:36 -0400289{
Jamie Madill8693bdb2017-09-02 15:32:14 -0400290 for (auto &bindingVec : mSamplerTextures)
Shannon Woods53a94a82014-06-24 15:20:36 -0400291 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800292 for (size_t textureIdx = 0; textureIdx < bindingVec.size(); textureIdx++)
Shannon Woods53a94a82014-06-24 15:20:36 -0400293 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800294 bindingVec[textureIdx].set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400295 }
296 }
Geoff Lang76b10c92014-09-05 16:28:14 -0400297 for (size_t samplerIdx = 0; samplerIdx < mSamplers.size(); samplerIdx++)
298 {
Jamie Madill4928b7c2017-06-20 12:57:39 -0400299 mSamplers[samplerIdx].set(context, nullptr);
Geoff Lang76b10c92014-09-05 16:28:14 -0400300 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400301
Xinghua Cao65ec0b22017-03-28 16:10:52 +0800302 for (auto &imageUnit : mImageUnits)
303 {
304 imageUnit.texture.set(context, nullptr);
305 imageUnit.level = 0;
306 imageUnit.layered = false;
307 imageUnit.layer = 0;
308 imageUnit.access = GL_READ_ONLY;
309 imageUnit.format = GL_R32UI;
310 }
311
Jamie Madill4928b7c2017-06-20 12:57:39 -0400312 mRenderbuffer.set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400313
Corentin Wallez336129f2017-10-17 15:55:40 -0400314 for (auto type : angle::AllEnums<BufferBinding>())
315 {
Jamie Madillbf5177d2018-08-21 12:58:20 -0400316 UpdateBufferBinding(context, &mBoundBuffers[type], nullptr, type);
Corentin Wallez336129f2017-10-17 15:55:40 -0400317 }
318
Geoff Lang7dd2e102014-11-10 15:19:26 -0500319 if (mProgram)
320 {
Jamie Madill6c1f6712017-02-14 19:08:04 -0500321 mProgram->release(context);
Geoff Lang7dd2e102014-11-10 15:19:26 -0500322 }
Yunchao Hed7297bf2017-04-19 15:27:10 +0800323 mProgram = nullptr;
Geoff Lang7dd2e102014-11-10 15:19:26 -0500324
Yunchao Hea336b902017-08-02 16:05:21 +0800325 mProgramPipeline.set(context, nullptr);
326
James Darpiniane8a93c62018-01-04 18:02:24 -0800327 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -0400328 mTransformFeedback->onBindingChanged(context, false);
Jamie Madill4928b7c2017-06-20 12:57:39 -0400329 mTransformFeedback.set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400330
Corentin Wallezad3ae902018-03-09 13:40:42 -0500331 for (QueryType type : angle::AllEnums<QueryType>())
Shannon Woods53a94a82014-06-24 15:20:36 -0400332 {
Corentin Wallezad3ae902018-03-09 13:40:42 -0500333 mActiveQueries[type].set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400334 }
335
Corentin Wallez336129f2017-10-17 15:55:40 -0400336 for (auto &buf : mUniformBuffers)
Shannon Woods53a94a82014-06-24 15:20:36 -0400337 {
Jamie Madillbf5177d2018-08-21 12:58:20 -0400338 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::Uniform, 0, 0);
Shannon Woods53a94a82014-06-24 15:20:36 -0400339 }
340
Jiajia Qin6eafb042016-12-27 17:04:07 +0800341 for (auto &buf : mAtomicCounterBuffers)
342 {
Jamie Madillbf5177d2018-08-21 12:58:20 -0400343 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::AtomicCounter, 0, 0);
Jiajia Qin6eafb042016-12-27 17:04:07 +0800344 }
345
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800346 for (auto &buf : mShaderStorageBuffers)
347 {
Jamie Madillbf5177d2018-08-21 12:58:20 -0400348 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::ShaderStorage, 0, 0);
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800349 }
350
Sami Väisänene45e53b2016-05-25 10:36:04 +0300351 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixProj);
352 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixMV);
353 mPathStencilFunc = GL_ALWAYS;
354 mPathStencilRef = 0;
355 mPathStencilMask = std::numeric_limits<GLuint>::max();
356
Jamie Madill1b94d432015-08-07 13:23:23 -0400357 // TODO(jmadill): Is this necessary?
358 setAllDirtyBits();
Shannon Woods53a94a82014-06-24 15:20:36 -0400359}
360
361const RasterizerState &State::getRasterizerState() const
362{
363 return mRasterizer;
364}
365
366const BlendState &State::getBlendState() const
367{
368 return mBlend;
369}
370
371const DepthStencilState &State::getDepthStencilState() const
372{
373 return mDepthStencil;
374}
375
Jamie Madillf75ab352015-03-16 10:46:52 -0400376void State::setColorClearValue(float red, float green, float blue, float alpha)
Shannon Woods53a94a82014-06-24 15:20:36 -0400377{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700378 mColorClearValue.red = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400379 mColorClearValue.green = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700380 mColorClearValue.blue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400381 mColorClearValue.alpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400382 mDirtyBits.set(DIRTY_BIT_CLEAR_COLOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400383}
384
Jamie Madillf75ab352015-03-16 10:46:52 -0400385void State::setDepthClearValue(float depth)
Shannon Woods53a94a82014-06-24 15:20:36 -0400386{
387 mDepthClearValue = depth;
Jamie Madill1b94d432015-08-07 13:23:23 -0400388 mDirtyBits.set(DIRTY_BIT_CLEAR_DEPTH);
Shannon Woods53a94a82014-06-24 15:20:36 -0400389}
390
Jamie Madillf75ab352015-03-16 10:46:52 -0400391void State::setStencilClearValue(int stencil)
Shannon Woods53a94a82014-06-24 15:20:36 -0400392{
393 mStencilClearValue = stencil;
Jamie Madill1b94d432015-08-07 13:23:23 -0400394 mDirtyBits.set(DIRTY_BIT_CLEAR_STENCIL);
Shannon Woods53a94a82014-06-24 15:20:36 -0400395}
396
Shannon Woods53a94a82014-06-24 15:20:36 -0400397void State::setColorMask(bool red, bool green, bool blue, bool alpha)
398{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700399 mBlend.colorMaskRed = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400400 mBlend.colorMaskGreen = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700401 mBlend.colorMaskBlue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400402 mBlend.colorMaskAlpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400403 mDirtyBits.set(DIRTY_BIT_COLOR_MASK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400404}
405
406void State::setDepthMask(bool mask)
407{
408 mDepthStencil.depthMask = mask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400409 mDirtyBits.set(DIRTY_BIT_DEPTH_MASK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400410}
411
412bool State::isRasterizerDiscardEnabled() const
413{
414 return mRasterizer.rasterizerDiscard;
415}
416
417void State::setRasterizerDiscard(bool enabled)
418{
419 mRasterizer.rasterizerDiscard = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400420 mDirtyBits.set(DIRTY_BIT_RASTERIZER_DISCARD_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400421}
422
423bool State::isCullFaceEnabled() const
424{
425 return mRasterizer.cullFace;
426}
427
428void State::setCullFace(bool enabled)
429{
430 mRasterizer.cullFace = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400431 mDirtyBits.set(DIRTY_BIT_CULL_FACE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400432}
433
Corentin Wallez2e568cf2017-09-18 17:05:22 -0400434void State::setCullMode(CullFaceMode mode)
Shannon Woods53a94a82014-06-24 15:20:36 -0400435{
436 mRasterizer.cullMode = mode;
Jamie Madill1b94d432015-08-07 13:23:23 -0400437 mDirtyBits.set(DIRTY_BIT_CULL_FACE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400438}
439
440void State::setFrontFace(GLenum front)
441{
442 mRasterizer.frontFace = front;
Jamie Madill1b94d432015-08-07 13:23:23 -0400443 mDirtyBits.set(DIRTY_BIT_FRONT_FACE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400444}
445
446bool State::isDepthTestEnabled() const
447{
448 return mDepthStencil.depthTest;
449}
450
451void State::setDepthTest(bool enabled)
452{
453 mDepthStencil.depthTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400454 mDirtyBits.set(DIRTY_BIT_DEPTH_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400455}
456
457void State::setDepthFunc(GLenum depthFunc)
458{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700459 mDepthStencil.depthFunc = depthFunc;
460 mDirtyBits.set(DIRTY_BIT_DEPTH_FUNC);
Shannon Woods53a94a82014-06-24 15:20:36 -0400461}
462
463void State::setDepthRange(float zNear, float zFar)
464{
465 mNearZ = zNear;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700466 mFarZ = zFar;
Jamie Madill1b94d432015-08-07 13:23:23 -0400467 mDirtyBits.set(DIRTY_BIT_DEPTH_RANGE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400468}
469
Geoff Langd42f5b82015-04-16 14:03:29 -0400470float State::getNearPlane() const
Shannon Woods53a94a82014-06-24 15:20:36 -0400471{
Geoff Langd42f5b82015-04-16 14:03:29 -0400472 return mNearZ;
473}
474
475float State::getFarPlane() const
476{
477 return mFarZ;
Shannon Woods53a94a82014-06-24 15:20:36 -0400478}
479
480bool State::isBlendEnabled() const
481{
482 return mBlend.blend;
483}
484
485void State::setBlend(bool enabled)
486{
487 mBlend.blend = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400488 mDirtyBits.set(DIRTY_BIT_BLEND_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400489}
490
491void State::setBlendFactors(GLenum sourceRGB, GLenum destRGB, GLenum sourceAlpha, GLenum destAlpha)
492{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700493 mBlend.sourceBlendRGB = sourceRGB;
494 mBlend.destBlendRGB = destRGB;
Shannon Woods53a94a82014-06-24 15:20:36 -0400495 mBlend.sourceBlendAlpha = sourceAlpha;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700496 mBlend.destBlendAlpha = destAlpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400497 mDirtyBits.set(DIRTY_BIT_BLEND_FUNCS);
Shannon Woods53a94a82014-06-24 15:20:36 -0400498}
499
500void State::setBlendColor(float red, float green, float blue, float alpha)
501{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700502 mBlendColor.red = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400503 mBlendColor.green = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700504 mBlendColor.blue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400505 mBlendColor.alpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400506 mDirtyBits.set(DIRTY_BIT_BLEND_COLOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400507}
508
509void State::setBlendEquation(GLenum rgbEquation, GLenum alphaEquation)
510{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700511 mBlend.blendEquationRGB = rgbEquation;
Shannon Woods53a94a82014-06-24 15:20:36 -0400512 mBlend.blendEquationAlpha = alphaEquation;
Jamie Madill1b94d432015-08-07 13:23:23 -0400513 mDirtyBits.set(DIRTY_BIT_BLEND_EQUATIONS);
Shannon Woods53a94a82014-06-24 15:20:36 -0400514}
515
516const ColorF &State::getBlendColor() const
517{
518 return mBlendColor;
519}
520
521bool State::isStencilTestEnabled() const
522{
523 return mDepthStencil.stencilTest;
524}
525
526void State::setStencilTest(bool enabled)
527{
528 mDepthStencil.stencilTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400529 mDirtyBits.set(DIRTY_BIT_STENCIL_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400530}
531
532void State::setStencilParams(GLenum stencilFunc, GLint stencilRef, GLuint stencilMask)
533{
534 mDepthStencil.stencilFunc = stencilFunc;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700535 mStencilRef = (stencilRef > 0) ? stencilRef : 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400536 mDepthStencil.stencilMask = stencilMask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400537 mDirtyBits.set(DIRTY_BIT_STENCIL_FUNCS_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400538}
539
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700540void State::setStencilBackParams(GLenum stencilBackFunc,
541 GLint stencilBackRef,
542 GLuint stencilBackMask)
Shannon Woods53a94a82014-06-24 15:20:36 -0400543{
544 mDepthStencil.stencilBackFunc = stencilBackFunc;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700545 mStencilBackRef = (stencilBackRef > 0) ? stencilBackRef : 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400546 mDepthStencil.stencilBackMask = stencilBackMask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400547 mDirtyBits.set(DIRTY_BIT_STENCIL_FUNCS_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400548}
549
550void State::setStencilWritemask(GLuint stencilWritemask)
551{
552 mDepthStencil.stencilWritemask = stencilWritemask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400553 mDirtyBits.set(DIRTY_BIT_STENCIL_WRITEMASK_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400554}
555
556void State::setStencilBackWritemask(GLuint stencilBackWritemask)
557{
558 mDepthStencil.stencilBackWritemask = stencilBackWritemask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400559 mDirtyBits.set(DIRTY_BIT_STENCIL_WRITEMASK_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400560}
561
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700562void State::setStencilOperations(GLenum stencilFail,
563 GLenum stencilPassDepthFail,
564 GLenum stencilPassDepthPass)
Shannon Woods53a94a82014-06-24 15:20:36 -0400565{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700566 mDepthStencil.stencilFail = stencilFail;
Shannon Woods53a94a82014-06-24 15:20:36 -0400567 mDepthStencil.stencilPassDepthFail = stencilPassDepthFail;
568 mDepthStencil.stencilPassDepthPass = stencilPassDepthPass;
Jamie Madill1b94d432015-08-07 13:23:23 -0400569 mDirtyBits.set(DIRTY_BIT_STENCIL_OPS_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400570}
571
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700572void State::setStencilBackOperations(GLenum stencilBackFail,
573 GLenum stencilBackPassDepthFail,
574 GLenum stencilBackPassDepthPass)
Shannon Woods53a94a82014-06-24 15:20:36 -0400575{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700576 mDepthStencil.stencilBackFail = stencilBackFail;
Shannon Woods53a94a82014-06-24 15:20:36 -0400577 mDepthStencil.stencilBackPassDepthFail = stencilBackPassDepthFail;
578 mDepthStencil.stencilBackPassDepthPass = stencilBackPassDepthPass;
Jamie Madill1b94d432015-08-07 13:23:23 -0400579 mDirtyBits.set(DIRTY_BIT_STENCIL_OPS_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400580}
581
582GLint State::getStencilRef() const
583{
584 return mStencilRef;
585}
586
587GLint State::getStencilBackRef() const
588{
589 return mStencilBackRef;
590}
591
592bool State::isPolygonOffsetFillEnabled() const
593{
594 return mRasterizer.polygonOffsetFill;
595}
596
597void State::setPolygonOffsetFill(bool enabled)
598{
Jamie Madill1b94d432015-08-07 13:23:23 -0400599 mRasterizer.polygonOffsetFill = enabled;
600 mDirtyBits.set(DIRTY_BIT_POLYGON_OFFSET_FILL_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400601}
602
603void State::setPolygonOffsetParams(GLfloat factor, GLfloat units)
604{
605 // An application can pass NaN values here, so handle this gracefully
606 mRasterizer.polygonOffsetFactor = factor != factor ? 0.0f : factor;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700607 mRasterizer.polygonOffsetUnits = units != units ? 0.0f : units;
Jamie Madill1b94d432015-08-07 13:23:23 -0400608 mDirtyBits.set(DIRTY_BIT_POLYGON_OFFSET);
Shannon Woods53a94a82014-06-24 15:20:36 -0400609}
610
611bool State::isSampleAlphaToCoverageEnabled() const
612{
613 return mBlend.sampleAlphaToCoverage;
614}
615
616void State::setSampleAlphaToCoverage(bool enabled)
617{
618 mBlend.sampleAlphaToCoverage = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400619 mDirtyBits.set(DIRTY_BIT_SAMPLE_ALPHA_TO_COVERAGE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400620}
621
622bool State::isSampleCoverageEnabled() const
623{
624 return mSampleCoverage;
625}
626
627void State::setSampleCoverage(bool enabled)
628{
629 mSampleCoverage = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400630 mDirtyBits.set(DIRTY_BIT_SAMPLE_COVERAGE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400631}
632
633void State::setSampleCoverageParams(GLclampf value, bool invert)
634{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700635 mSampleCoverageValue = value;
Shannon Woods53a94a82014-06-24 15:20:36 -0400636 mSampleCoverageInvert = invert;
Jamie Madill1b94d432015-08-07 13:23:23 -0400637 mDirtyBits.set(DIRTY_BIT_SAMPLE_COVERAGE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400638}
639
Geoff Lang0fbb6002015-04-16 11:11:53 -0400640GLclampf State::getSampleCoverageValue() const
Shannon Woods53a94a82014-06-24 15:20:36 -0400641{
Geoff Lang0fbb6002015-04-16 11:11:53 -0400642 return mSampleCoverageValue;
643}
Shannon Woods53a94a82014-06-24 15:20:36 -0400644
Geoff Lang0fbb6002015-04-16 11:11:53 -0400645bool State::getSampleCoverageInvert() const
646{
647 return mSampleCoverageInvert;
Shannon Woods53a94a82014-06-24 15:20:36 -0400648}
649
Jiawei Shaodb342272017-09-27 10:21:45 +0800650bool State::isSampleMaskEnabled() const
651{
652 return mSampleMask;
653}
654
655void State::setSampleMaskEnabled(bool enabled)
656{
657 mSampleMask = enabled;
658 mDirtyBits.set(DIRTY_BIT_SAMPLE_MASK_ENABLED);
659}
660
661void State::setSampleMaskParams(GLuint maskNumber, GLbitfield mask)
662{
663 ASSERT(maskNumber < mMaxSampleMaskWords);
664 mSampleMaskValues[maskNumber] = mask;
Jamie Madillc67323a2017-11-02 23:11:41 -0400665 // TODO(jmadill): Use a child dirty bit if we ever use more than two words.
666 mDirtyBits.set(DIRTY_BIT_SAMPLE_MASK);
Jiawei Shaodb342272017-09-27 10:21:45 +0800667}
668
669GLbitfield State::getSampleMaskWord(GLuint maskNumber) const
670{
671 ASSERT(maskNumber < mMaxSampleMaskWords);
672 return mSampleMaskValues[maskNumber];
673}
674
675GLuint State::getMaxSampleMaskWords() const
676{
677 return mMaxSampleMaskWords;
678}
679
Sami Väisänen74c23472016-05-09 17:30:30 +0300680void State::setSampleAlphaToOne(bool enabled)
681{
682 mSampleAlphaToOne = enabled;
683 mDirtyBits.set(DIRTY_BIT_SAMPLE_ALPHA_TO_ONE);
684}
685
686bool State::isSampleAlphaToOneEnabled() const
687{
688 return mSampleAlphaToOne;
689}
690
691void State::setMultisampling(bool enabled)
692{
693 mMultiSampling = enabled;
694 mDirtyBits.set(DIRTY_BIT_MULTISAMPLING);
695}
696
697bool State::isMultisamplingEnabled() const
698{
699 return mMultiSampling;
700}
701
Shannon Woods53a94a82014-06-24 15:20:36 -0400702bool State::isScissorTestEnabled() const
703{
704 return mScissorTest;
705}
706
707void State::setScissorTest(bool enabled)
708{
709 mScissorTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400710 mDirtyBits.set(DIRTY_BIT_SCISSOR_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400711}
712
713void State::setScissorParams(GLint x, GLint y, GLsizei width, GLsizei height)
714{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700715 mScissor.x = x;
716 mScissor.y = y;
717 mScissor.width = width;
Shannon Woods53a94a82014-06-24 15:20:36 -0400718 mScissor.height = height;
Jamie Madill1b94d432015-08-07 13:23:23 -0400719 mDirtyBits.set(DIRTY_BIT_SCISSOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400720}
721
722const Rectangle &State::getScissor() const
723{
724 return mScissor;
725}
726
727bool State::isDitherEnabled() const
728{
729 return mBlend.dither;
730}
731
732void State::setDither(bool enabled)
733{
734 mBlend.dither = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400735 mDirtyBits.set(DIRTY_BIT_DITHER_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400736}
737
Jamie Madillb4b53c52015-02-03 15:22:48 -0500738bool State::isPrimitiveRestartEnabled() const
739{
740 return mPrimitiveRestart;
741}
742
743void State::setPrimitiveRestart(bool enabled)
744{
745 mPrimitiveRestart = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400746 mDirtyBits.set(DIRTY_BIT_PRIMITIVE_RESTART_ENABLED);
Jamie Madillb4b53c52015-02-03 15:22:48 -0500747}
748
Shannon Woods53a94a82014-06-24 15:20:36 -0400749void State::setEnableFeature(GLenum feature, bool enabled)
750{
751 switch (feature)
752 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700753 case GL_MULTISAMPLE_EXT:
754 setMultisampling(enabled);
755 break;
756 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
757 setSampleAlphaToOne(enabled);
758 break;
759 case GL_CULL_FACE:
760 setCullFace(enabled);
761 break;
762 case GL_POLYGON_OFFSET_FILL:
763 setPolygonOffsetFill(enabled);
764 break;
765 case GL_SAMPLE_ALPHA_TO_COVERAGE:
766 setSampleAlphaToCoverage(enabled);
767 break;
768 case GL_SAMPLE_COVERAGE:
769 setSampleCoverage(enabled);
770 break;
771 case GL_SCISSOR_TEST:
772 setScissorTest(enabled);
773 break;
774 case GL_STENCIL_TEST:
775 setStencilTest(enabled);
776 break;
777 case GL_DEPTH_TEST:
778 setDepthTest(enabled);
779 break;
780 case GL_BLEND:
781 setBlend(enabled);
782 break;
783 case GL_DITHER:
784 setDither(enabled);
785 break;
786 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
787 setPrimitiveRestart(enabled);
788 break;
789 case GL_RASTERIZER_DISCARD:
790 setRasterizerDiscard(enabled);
791 break;
792 case GL_SAMPLE_MASK:
793 setSampleMaskEnabled(enabled);
794 break;
795 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
796 mDebug.setOutputSynchronous(enabled);
797 break;
798 case GL_DEBUG_OUTPUT:
799 mDebug.setOutputEnabled(enabled);
800 break;
801 case GL_FRAMEBUFFER_SRGB_EXT:
802 setFramebufferSRGB(enabled);
803 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -0700804
805 // GLES1 emulation
806 case GL_ALPHA_TEST:
807 mGLES1State.mAlphaTestEnabled = enabled;
808 break;
Lingfeng Yang23dc90b2018-04-23 09:01:49 -0700809 case GL_TEXTURE_2D:
810 mGLES1State.mTexUnitEnables[mActiveSampler].set(TextureType::_2D, enabled);
811 break;
812 case GL_TEXTURE_CUBE_MAP:
813 mGLES1State.mTexUnitEnables[mActiveSampler].set(TextureType::CubeMap, enabled);
814 break;
Lingfeng Yangd0febe72018-05-17 22:36:52 -0700815 case GL_LIGHTING:
816 mGLES1State.mLightingEnabled = enabled;
817 break;
818 case GL_LIGHT0:
819 case GL_LIGHT1:
820 case GL_LIGHT2:
821 case GL_LIGHT3:
822 case GL_LIGHT4:
823 case GL_LIGHT5:
824 case GL_LIGHT6:
825 case GL_LIGHT7:
826 mGLES1State.mLights[feature - GL_LIGHT0].enabled = enabled;
827 break;
828 case GL_NORMALIZE:
829 mGLES1State.mNormalizeEnabled = enabled;
830 break;
831 case GL_RESCALE_NORMAL:
832 mGLES1State.mRescaleNormalEnabled = enabled;
833 break;
834 case GL_COLOR_MATERIAL:
835 mGLES1State.mColorMaterialEnabled = enabled;
836 break;
Lingfeng Yang060088a2018-05-30 20:40:57 -0700837 case GL_CLIP_PLANE0:
838 case GL_CLIP_PLANE1:
839 case GL_CLIP_PLANE2:
840 case GL_CLIP_PLANE3:
841 case GL_CLIP_PLANE4:
842 case GL_CLIP_PLANE5:
843 mGLES1State.mClipPlanes[feature - GL_CLIP_PLANE0].enabled = enabled;
844 break;
Lingfeng Yang7ba3f422018-06-01 09:43:04 -0700845 case GL_FOG:
846 mGLES1State.mFogEnabled = enabled;
847 break;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -0700848 case GL_POINT_SMOOTH:
849 mGLES1State.mPointSmoothEnabled = enabled;
850 break;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -0700851 case GL_LINE_SMOOTH:
852 mGLES1State.mLineSmoothEnabled = enabled;
853 break;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -0700854 case GL_POINT_SPRITE_OES:
855 mGLES1State.mPointSpriteEnabled = enabled;
856 break;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -0700857 case GL_COLOR_LOGIC_OP:
858 mGLES1State.mLogicOpEnabled = enabled;
859 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700860 default:
861 UNREACHABLE();
Shannon Woods53a94a82014-06-24 15:20:36 -0400862 }
863}
864
Jamie Madilldfde6ab2016-06-09 07:07:18 -0700865bool State::getEnableFeature(GLenum feature) const
Shannon Woods53a94a82014-06-24 15:20:36 -0400866{
867 switch (feature)
868 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700869 case GL_MULTISAMPLE_EXT:
870 return isMultisamplingEnabled();
871 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
872 return isSampleAlphaToOneEnabled();
873 case GL_CULL_FACE:
874 return isCullFaceEnabled();
875 case GL_POLYGON_OFFSET_FILL:
876 return isPolygonOffsetFillEnabled();
877 case GL_SAMPLE_ALPHA_TO_COVERAGE:
878 return isSampleAlphaToCoverageEnabled();
879 case GL_SAMPLE_COVERAGE:
880 return isSampleCoverageEnabled();
881 case GL_SCISSOR_TEST:
882 return isScissorTestEnabled();
883 case GL_STENCIL_TEST:
884 return isStencilTestEnabled();
885 case GL_DEPTH_TEST:
886 return isDepthTestEnabled();
887 case GL_BLEND:
888 return isBlendEnabled();
889 case GL_DITHER:
890 return isDitherEnabled();
891 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
892 return isPrimitiveRestartEnabled();
893 case GL_RASTERIZER_DISCARD:
894 return isRasterizerDiscardEnabled();
895 case GL_SAMPLE_MASK:
896 return isSampleMaskEnabled();
897 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
898 return mDebug.isOutputSynchronous();
899 case GL_DEBUG_OUTPUT:
900 return mDebug.isOutputEnabled();
901 case GL_BIND_GENERATES_RESOURCE_CHROMIUM:
902 return isBindGeneratesResourceEnabled();
903 case GL_CLIENT_ARRAYS_ANGLE:
904 return areClientArraysEnabled();
905 case GL_FRAMEBUFFER_SRGB_EXT:
906 return getFramebufferSRGB();
907 case GL_ROBUST_RESOURCE_INITIALIZATION_ANGLE:
908 return mRobustResourceInit;
909 case GL_PROGRAM_CACHE_ENABLED_ANGLE:
910 return mProgramBinaryCacheEnabled;
Jamie Madillc43be722017-07-13 16:22:14 -0400911
Lingfeng Yang13b708f2018-03-21 12:14:10 -0700912 // GLES1 emulation
913 case GL_ALPHA_TEST:
914 return mGLES1State.mAlphaTestEnabled;
Lingfeng Yang01074432018-04-16 10:19:51 -0700915 case GL_VERTEX_ARRAY:
916 return mGLES1State.mVertexArrayEnabled;
917 case GL_NORMAL_ARRAY:
918 return mGLES1State.mNormalArrayEnabled;
919 case GL_COLOR_ARRAY:
920 return mGLES1State.mColorArrayEnabled;
921 case GL_POINT_SIZE_ARRAY_OES:
922 return mGLES1State.mPointSizeArrayEnabled;
923 case GL_TEXTURE_COORD_ARRAY:
924 return mGLES1State.mTexCoordArrayEnabled[mGLES1State.mClientActiveTexture];
Lingfeng Yang23dc90b2018-04-23 09:01:49 -0700925 case GL_TEXTURE_2D:
926 return mGLES1State.mTexUnitEnables[mActiveSampler].test(TextureType::_2D);
927 case GL_TEXTURE_CUBE_MAP:
928 return mGLES1State.mTexUnitEnables[mActiveSampler].test(TextureType::CubeMap);
Lingfeng Yangd0febe72018-05-17 22:36:52 -0700929 case GL_LIGHTING:
930 return mGLES1State.mLightingEnabled;
931 case GL_LIGHT0:
932 case GL_LIGHT1:
933 case GL_LIGHT2:
934 case GL_LIGHT3:
935 case GL_LIGHT4:
936 case GL_LIGHT5:
937 case GL_LIGHT6:
938 case GL_LIGHT7:
939 return mGLES1State.mLights[feature - GL_LIGHT0].enabled;
940 case GL_NORMALIZE:
941 return mGLES1State.mNormalizeEnabled;
942 case GL_RESCALE_NORMAL:
943 return mGLES1State.mRescaleNormalEnabled;
944 case GL_COLOR_MATERIAL:
945 return mGLES1State.mColorMaterialEnabled;
Lingfeng Yang060088a2018-05-30 20:40:57 -0700946 case GL_CLIP_PLANE0:
947 case GL_CLIP_PLANE1:
948 case GL_CLIP_PLANE2:
949 case GL_CLIP_PLANE3:
950 case GL_CLIP_PLANE4:
951 case GL_CLIP_PLANE5:
952 return mGLES1State.mClipPlanes[feature - GL_CLIP_PLANE0].enabled;
Lingfeng Yang7ba3f422018-06-01 09:43:04 -0700953 case GL_FOG:
954 return mGLES1State.mFogEnabled;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -0700955 case GL_POINT_SMOOTH:
956 return mGLES1State.mPointSmoothEnabled;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -0700957 case GL_LINE_SMOOTH:
958 return mGLES1State.mLineSmoothEnabled;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -0700959 case GL_POINT_SPRITE_OES:
960 return mGLES1State.mPointSpriteEnabled;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -0700961 case GL_COLOR_LOGIC_OP:
962 return mGLES1State.mLogicOpEnabled;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700963 default:
964 UNREACHABLE();
965 return false;
Shannon Woods53a94a82014-06-24 15:20:36 -0400966 }
967}
968
969void State::setLineWidth(GLfloat width)
970{
971 mLineWidth = width;
Jamie Madill1b94d432015-08-07 13:23:23 -0400972 mDirtyBits.set(DIRTY_BIT_LINE_WIDTH);
Shannon Woods53a94a82014-06-24 15:20:36 -0400973}
974
Geoff Lang4b3f4162015-04-16 13:22:05 -0400975float State::getLineWidth() const
976{
977 return mLineWidth;
978}
979
Shannon Woods53a94a82014-06-24 15:20:36 -0400980void State::setGenerateMipmapHint(GLenum hint)
981{
982 mGenerateMipmapHint = hint;
Jamie Madill1b94d432015-08-07 13:23:23 -0400983 mDirtyBits.set(DIRTY_BIT_GENERATE_MIPMAP_HINT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400984}
985
986void State::setFragmentShaderDerivativeHint(GLenum hint)
987{
988 mFragmentShaderDerivativeHint = hint;
Jamie Madill1b94d432015-08-07 13:23:23 -0400989 mDirtyBits.set(DIRTY_BIT_SHADER_DERIVATIVE_HINT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400990 // TODO: Propagate the hint to shader translator so we can write
991 // ddx, ddx_coarse, or ddx_fine depending on the hint.
992 // Ignore for now. It is valid for implementations to ignore hint.
993}
994
Geoff Langfeb8c682017-02-13 16:07:35 -0500995bool State::areClientArraysEnabled() const
996{
997 return mClientArraysEnabled;
998}
999
Shannon Woods53a94a82014-06-24 15:20:36 -04001000void State::setViewportParams(GLint x, GLint y, GLsizei width, GLsizei height)
1001{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001002 mViewport.x = x;
1003 mViewport.y = y;
1004 mViewport.width = width;
Shannon Woods53a94a82014-06-24 15:20:36 -04001005 mViewport.height = height;
Jamie Madill1b94d432015-08-07 13:23:23 -04001006 mDirtyBits.set(DIRTY_BIT_VIEWPORT);
Shannon Woods53a94a82014-06-24 15:20:36 -04001007}
1008
1009const Rectangle &State::getViewport() const
1010{
1011 return mViewport;
1012}
1013
1014void State::setActiveSampler(unsigned int active)
1015{
1016 mActiveSampler = active;
1017}
1018
1019unsigned int State::getActiveSampler() const
1020{
Cooper Partin4d61f7e2015-08-12 10:56:50 -07001021 return static_cast<unsigned int>(mActiveSampler);
Shannon Woods53a94a82014-06-24 15:20:36 -04001022}
1023
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001024void State::setSamplerTexture(const Context *context, TextureType type, Texture *texture)
Shannon Woods53a94a82014-06-24 15:20:36 -04001025{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001026 mSamplerTextures[type][mActiveSampler].set(context, texture);
Jamie Madill81c2e252017-09-09 23:32:46 -04001027 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
1028 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Shannon Woods53a94a82014-06-24 15:20:36 -04001029}
1030
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001031Texture *State::getTargetTexture(TextureType type) const
Jamie Madillc29968b2016-01-20 11:17:23 -05001032{
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001033 return getSamplerTexture(static_cast<unsigned int>(mActiveSampler), type);
Jamie Madillc29968b2016-01-20 11:17:23 -05001034}
1035
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001036GLuint State::getSamplerTextureId(unsigned int sampler, TextureType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001037{
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001038 ASSERT(sampler < mSamplerTextures[type].size());
1039 return mSamplerTextures[type][sampler].id();
Shannon Woods53a94a82014-06-24 15:20:36 -04001040}
1041
Jamie Madilla02315b2017-02-23 14:14:47 -05001042void State::detachTexture(const Context *context, const TextureMap &zeroTextures, GLuint texture)
Shannon Woods53a94a82014-06-24 15:20:36 -04001043{
1044 // Textures have a detach method on State rather than a simple
1045 // removeBinding, because the zero/null texture objects are managed
1046 // separately, and don't have to go through the Context's maps or
1047 // the ResourceManager.
1048
1049 // [OpenGL ES 2.0.24] section 3.8 page 84:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001050 // If a texture object is deleted, it is as if all texture units which are bound to that texture
1051 // object are rebound to texture object zero
Shannon Woods53a94a82014-06-24 15:20:36 -04001052
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001053 for (TextureType type : angle::AllEnums<TextureType>())
Shannon Woods53a94a82014-06-24 15:20:36 -04001054 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001055 TextureBindingVector &textureVector = mSamplerTextures[type];
Jamie Madill81c2e252017-09-09 23:32:46 -04001056 for (BindingPointer<Texture> &binding : textureVector)
Shannon Woods53a94a82014-06-24 15:20:36 -04001057 {
Geoff Lang76b10c92014-09-05 16:28:14 -04001058 if (binding.id() == texture)
Shannon Woods53a94a82014-06-24 15:20:36 -04001059 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001060 Texture *zeroTexture = zeroTextures[type].get();
1061 ASSERT(zeroTexture != nullptr);
Jamie Madille6382c32014-11-07 15:05:26 -05001062 // Zero textures are the "default" textures instead of NULL
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001063 binding.set(context, zeroTexture);
Jamie Madill81c2e252017-09-09 23:32:46 -04001064 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
Shannon Woods53a94a82014-06-24 15:20:36 -04001065 }
1066 }
1067 }
1068
Xinghua Cao65ec0b22017-03-28 16:10:52 +08001069 for (auto &bindingImageUnit : mImageUnits)
1070 {
1071 if (bindingImageUnit.texture.id() == texture)
1072 {
1073 bindingImageUnit.texture.set(context, nullptr);
1074 bindingImageUnit.level = 0;
1075 bindingImageUnit.layered = false;
1076 bindingImageUnit.layer = 0;
1077 bindingImageUnit.access = GL_READ_ONLY;
1078 bindingImageUnit.format = GL_R32UI;
1079 break;
1080 }
1081 }
1082
Shannon Woods53a94a82014-06-24 15:20:36 -04001083 // [OpenGL ES 2.0.24] section 4.4 page 112:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001084 // If a texture object is deleted while its image is attached to the currently bound
1085 // framebuffer, then it is as if Texture2DAttachment had been called, with a texture of 0, for
1086 // each attachment point to which this image was attached in the currently bound framebuffer.
Shannon Woods53a94a82014-06-24 15:20:36 -04001087
Jamie Madill8693bdb2017-09-02 15:32:14 -04001088 if (mReadFramebuffer && mReadFramebuffer->detachTexture(context, texture))
Shannon Woods53a94a82014-06-24 15:20:36 -04001089 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001090 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
Shannon Woods53a94a82014-06-24 15:20:36 -04001091 }
1092
Jamie Madill8693bdb2017-09-02 15:32:14 -04001093 if (mDrawFramebuffer && mDrawFramebuffer->detachTexture(context, texture))
Shannon Woods53a94a82014-06-24 15:20:36 -04001094 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001095 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
Shannon Woods53a94a82014-06-24 15:20:36 -04001096 }
1097}
1098
Jamie Madill4928b7c2017-06-20 12:57:39 -04001099void State::initializeZeroTextures(const Context *context, const TextureMap &zeroTextures)
Jamie Madille6382c32014-11-07 15:05:26 -05001100{
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001101 for (TextureType type : angle::AllEnums<TextureType>())
Jamie Madille6382c32014-11-07 15:05:26 -05001102 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001103 for (size_t textureUnit = 0; textureUnit < mSamplerTextures[type].size(); ++textureUnit)
Jamie Madille6382c32014-11-07 15:05:26 -05001104 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001105 mSamplerTextures[type][textureUnit].set(context, zeroTextures[type].get());
Jamie Madille6382c32014-11-07 15:05:26 -05001106 }
1107 }
1108}
1109
Jamie Madill4928b7c2017-06-20 12:57:39 -04001110void State::setSamplerBinding(const Context *context, GLuint textureUnit, Sampler *sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001111{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001112 mSamplers[textureUnit].set(context, sampler);
Jamie Madill81c2e252017-09-09 23:32:46 -04001113 mDirtyBits.set(DIRTY_BIT_SAMPLER_BINDINGS);
1114 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Jamie Madille25b8002018-09-20 13:39:49 -04001115 // This is overly conservative as it assumes the sampler has never been bound.
1116 setSamplerDirty(textureUnit);
Shannon Woods53a94a82014-06-24 15:20:36 -04001117}
1118
1119GLuint State::getSamplerId(GLuint textureUnit) const
1120{
Geoff Lang76b10c92014-09-05 16:28:14 -04001121 ASSERT(textureUnit < mSamplers.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001122 return mSamplers[textureUnit].id();
1123}
1124
Jamie Madill4928b7c2017-06-20 12:57:39 -04001125void State::detachSampler(const Context *context, GLuint sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001126{
1127 // [OpenGL ES 3.0.2] section 3.8.2 pages 123-124:
1128 // If a sampler object that is currently bound to one or more texture units is
1129 // deleted, it is as though BindSampler is called once for each texture unit to
1130 // which the sampler is bound, with unit set to the texture unit and sampler set to zero.
Jamie Madill81c2e252017-09-09 23:32:46 -04001131 for (BindingPointer<Sampler> &samplerBinding : mSamplers)
Shannon Woods53a94a82014-06-24 15:20:36 -04001132 {
Geoff Lang76b10c92014-09-05 16:28:14 -04001133 if (samplerBinding.id() == sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001134 {
Jamie Madill4928b7c2017-06-20 12:57:39 -04001135 samplerBinding.set(context, nullptr);
Jamie Madill81c2e252017-09-09 23:32:46 -04001136 mDirtyBits.set(DIRTY_BIT_SAMPLER_BINDINGS);
Shannon Woods53a94a82014-06-24 15:20:36 -04001137 }
1138 }
1139}
1140
Jamie Madill4928b7c2017-06-20 12:57:39 -04001141void State::setRenderbufferBinding(const Context *context, Renderbuffer *renderbuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001142{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001143 mRenderbuffer.set(context, renderbuffer);
Jamie Madill8693bdb2017-09-02 15:32:14 -04001144 mDirtyBits.set(DIRTY_BIT_RENDERBUFFER_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001145}
1146
1147GLuint State::getRenderbufferId() const
1148{
1149 return mRenderbuffer.id();
1150}
1151
Jamie Madilldfde6ab2016-06-09 07:07:18 -07001152Renderbuffer *State::getCurrentRenderbuffer() const
Shannon Woods53a94a82014-06-24 15:20:36 -04001153{
1154 return mRenderbuffer.get();
1155}
1156
Jamie Madilla02315b2017-02-23 14:14:47 -05001157void State::detachRenderbuffer(const Context *context, GLuint renderbuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001158{
1159 // [OpenGL ES 2.0.24] section 4.4 page 109:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001160 // If a renderbuffer that is currently bound to RENDERBUFFER is deleted, it is as though
1161 // BindRenderbuffer had been executed with the target RENDERBUFFER and name of zero.
Shannon Woods53a94a82014-06-24 15:20:36 -04001162
1163 if (mRenderbuffer.id() == renderbuffer)
1164 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001165 setRenderbufferBinding(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001166 }
1167
1168 // [OpenGL ES 2.0.24] section 4.4 page 111:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001169 // If a renderbuffer object is deleted while its image is attached to the currently bound
1170 // framebuffer, then it is as if FramebufferRenderbuffer had been called, with a renderbuffer of
1171 // 0, for each attachment point to which this image was attached in the currently bound
1172 // framebuffer.
Shannon Woods53a94a82014-06-24 15:20:36 -04001173
1174 Framebuffer *readFramebuffer = mReadFramebuffer;
1175 Framebuffer *drawFramebuffer = mDrawFramebuffer;
1176
Jamie Madill8693bdb2017-09-02 15:32:14 -04001177 if (readFramebuffer && readFramebuffer->detachRenderbuffer(context, renderbuffer))
Shannon Woods53a94a82014-06-24 15:20:36 -04001178 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001179 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
Shannon Woods53a94a82014-06-24 15:20:36 -04001180 }
1181
1182 if (drawFramebuffer && drawFramebuffer != readFramebuffer)
1183 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001184 if (drawFramebuffer->detachRenderbuffer(context, renderbuffer))
1185 {
1186 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
1187 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001188 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001189}
1190
1191void State::setReadFramebufferBinding(Framebuffer *framebuffer)
1192{
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001193 if (mReadFramebuffer == framebuffer)
1194 return;
1195
Shannon Woods53a94a82014-06-24 15:20:36 -04001196 mReadFramebuffer = framebuffer;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001197 mDirtyBits.set(DIRTY_BIT_READ_FRAMEBUFFER_BINDING);
1198
1199 if (mReadFramebuffer && mReadFramebuffer->hasAnyDirtyBit())
1200 {
1201 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
1202 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001203}
1204
1205void State::setDrawFramebufferBinding(Framebuffer *framebuffer)
1206{
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001207 if (mDrawFramebuffer == framebuffer)
1208 return;
1209
Shannon Woods53a94a82014-06-24 15:20:36 -04001210 mDrawFramebuffer = framebuffer;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001211 mDirtyBits.set(DIRTY_BIT_DRAW_FRAMEBUFFER_BINDING);
1212
1213 if (mDrawFramebuffer && mDrawFramebuffer->hasAnyDirtyBit())
1214 {
1215 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
1216 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001217}
1218
1219Framebuffer *State::getTargetFramebuffer(GLenum target) const
1220{
1221 switch (target)
1222 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001223 case GL_READ_FRAMEBUFFER_ANGLE:
1224 return mReadFramebuffer;
1225 case GL_DRAW_FRAMEBUFFER_ANGLE:
1226 case GL_FRAMEBUFFER:
1227 return mDrawFramebuffer;
1228 default:
1229 UNREACHABLE();
Yunchao Hef81ce4a2017-04-24 10:49:17 +08001230 return nullptr;
Shannon Woods53a94a82014-06-24 15:20:36 -04001231 }
1232}
1233
Jamie Madill51f40ec2016-06-15 14:06:00 -04001234Framebuffer *State::getReadFramebuffer() const
Shannon Woods53a94a82014-06-24 15:20:36 -04001235{
1236 return mReadFramebuffer;
1237}
1238
Shannon Woods53a94a82014-06-24 15:20:36 -04001239bool State::removeReadFramebufferBinding(GLuint framebuffer)
1240{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001241 if (mReadFramebuffer != nullptr && mReadFramebuffer->id() == framebuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001242 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001243 setReadFramebufferBinding(nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001244 return true;
1245 }
1246
1247 return false;
1248}
1249
1250bool State::removeDrawFramebufferBinding(GLuint framebuffer)
1251{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001252 if (mReadFramebuffer != nullptr && mDrawFramebuffer->id() == framebuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001253 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001254 setDrawFramebufferBinding(nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001255 return true;
1256 }
1257
1258 return false;
1259}
1260
Jamie Madill7267aa62018-04-17 15:28:21 -04001261void State::setVertexArrayBinding(const Context *context, VertexArray *vertexArray)
Shannon Woods53a94a82014-06-24 15:20:36 -04001262{
James Darpiniane8a93c62018-01-04 18:02:24 -08001263 if (mVertexArray == vertexArray)
1264 return;
1265 if (mVertexArray)
Jamie Madillbf5177d2018-08-21 12:58:20 -04001266 mVertexArray->onBindingChanged(context, -1);
Shannon Woods53a94a82014-06-24 15:20:36 -04001267 mVertexArray = vertexArray;
James Darpiniane8a93c62018-01-04 18:02:24 -08001268 if (vertexArray)
Jamie Madillbf5177d2018-08-21 12:58:20 -04001269 vertexArray->onBindingChanged(context, 1);
Jamie Madill0b9e9032015-08-17 11:51:52 +00001270 mDirtyBits.set(DIRTY_BIT_VERTEX_ARRAY_BINDING);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001271
1272 if (mVertexArray && mVertexArray->hasAnyDirtyBit())
1273 {
1274 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1275 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001276}
1277
1278GLuint State::getVertexArrayId() const
1279{
Yunchao He4f285442017-04-21 12:15:49 +08001280 ASSERT(mVertexArray != nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001281 return mVertexArray->id();
1282}
1283
Jamie Madill7267aa62018-04-17 15:28:21 -04001284bool State::removeVertexArrayBinding(const Context *context, GLuint vertexArray)
Shannon Woods53a94a82014-06-24 15:20:36 -04001285{
James Darpiniane8a93c62018-01-04 18:02:24 -08001286 if (mVertexArray && mVertexArray->id() == vertexArray)
Shannon Woods53a94a82014-06-24 15:20:36 -04001287 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001288 mVertexArray->onBindingChanged(context, -1);
Yunchao Hed7297bf2017-04-19 15:27:10 +08001289 mVertexArray = nullptr;
Jamie Madill0b9e9032015-08-17 11:51:52 +00001290 mDirtyBits.set(DIRTY_BIT_VERTEX_ARRAY_BINDING);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001291 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001292 return true;
1293 }
1294
1295 return false;
1296}
1297
Jamie Madill4928b7c2017-06-20 12:57:39 -04001298void State::bindVertexBuffer(const Context *context,
1299 GLuint bindingIndex,
Shao80957d92017-02-20 21:25:59 +08001300 Buffer *boundBuffer,
1301 GLintptr offset,
1302 GLsizei stride)
1303{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001304 getVertexArray()->bindVertexBuffer(context, bindingIndex, boundBuffer, offset, stride);
Shao80957d92017-02-20 21:25:59 +08001305 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1306}
1307
Shaodde78e82017-05-22 14:13:27 +08001308void State::setVertexAttribBinding(const Context *context, GLuint attribIndex, GLuint bindingIndex)
Shao80957d92017-02-20 21:25:59 +08001309{
Shaodde78e82017-05-22 14:13:27 +08001310 getVertexArray()->setVertexAttribBinding(context, attribIndex, bindingIndex);
Shao80957d92017-02-20 21:25:59 +08001311 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1312}
1313
1314void State::setVertexAttribFormat(GLuint attribIndex,
1315 GLint size,
1316 GLenum type,
1317 bool normalized,
1318 bool pureInteger,
1319 GLuint relativeOffset)
1320{
1321 getVertexArray()->setVertexAttribFormat(attribIndex, size, type, normalized, pureInteger,
1322 relativeOffset);
1323 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1324}
1325
1326void State::setVertexBindingDivisor(GLuint bindingIndex, GLuint divisor)
1327{
1328 getVertexArray()->setVertexBindingDivisor(bindingIndex, divisor);
1329 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1330}
1331
Jamie Madill6c1f6712017-02-14 19:08:04 -05001332void State::setProgram(const Context *context, Program *newProgram)
Shannon Woods53a94a82014-06-24 15:20:36 -04001333{
Geoff Lang7dd2e102014-11-10 15:19:26 -05001334 if (mProgram != newProgram)
Shannon Woods53a94a82014-06-24 15:20:36 -04001335 {
Geoff Lang7dd2e102014-11-10 15:19:26 -05001336 if (mProgram)
1337 {
Jamie Madill6c1f6712017-02-14 19:08:04 -05001338 mProgram->release(context);
Geoff Lang7dd2e102014-11-10 15:19:26 -05001339 }
1340
1341 mProgram = newProgram;
1342
1343 if (mProgram)
1344 {
1345 newProgram->addRef();
Jamie Madill81c2e252017-09-09 23:32:46 -04001346 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Geoff Lang7dd2e102014-11-10 15:19:26 -05001347 }
Jamie Madilla779b612017-07-24 11:46:05 -04001348 mDirtyBits.set(DIRTY_BIT_PROGRAM_EXECUTABLE);
1349 mDirtyBits.set(DIRTY_BIT_PROGRAM_BINDING);
Jamie Madill70aeda42018-08-20 12:17:40 -04001350 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM);
Shannon Woods53a94a82014-06-24 15:20:36 -04001351 }
1352}
1353
Jamie Madill4928b7c2017-06-20 12:57:39 -04001354void State::setTransformFeedbackBinding(const Context *context,
1355 TransformFeedback *transformFeedback)
Shannon Woods53a94a82014-06-24 15:20:36 -04001356{
James Darpiniane8a93c62018-01-04 18:02:24 -08001357 if (transformFeedback == mTransformFeedback.get())
1358 return;
1359 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -04001360 mTransformFeedback->onBindingChanged(context, false);
Jamie Madill4928b7c2017-06-20 12:57:39 -04001361 mTransformFeedback.set(context, transformFeedback);
James Darpiniane8a93c62018-01-04 18:02:24 -08001362 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -04001363 mTransformFeedback->onBindingChanged(context, true);
Geoff Langded79232017-11-28 15:21:11 -05001364 mDirtyBits.set(DIRTY_BIT_TRANSFORM_FEEDBACK_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001365}
1366
Gregoire Payen de La Garanderie52742022015-02-04 14:55:39 +00001367bool State::isTransformFeedbackActiveUnpaused() const
1368{
Jamie Madill4166f012018-05-31 14:53:30 -04001369 TransformFeedback *curTransformFeedback = mTransformFeedback.get();
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001370 return curTransformFeedback && curTransformFeedback->isActive() &&
1371 !curTransformFeedback->isPaused();
Gregoire Payen de La Garanderie52742022015-02-04 14:55:39 +00001372}
1373
Jamie Madill4928b7c2017-06-20 12:57:39 -04001374bool State::removeTransformFeedbackBinding(const Context *context, GLuint transformFeedback)
Shannon Woods53a94a82014-06-24 15:20:36 -04001375{
1376 if (mTransformFeedback.id() == transformFeedback)
1377 {
James Darpiniane8a93c62018-01-04 18:02:24 -08001378 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -04001379 mTransformFeedback->onBindingChanged(context, false);
Jamie Madill4928b7c2017-06-20 12:57:39 -04001380 mTransformFeedback.set(context, nullptr);
Corentin Walleza2257da2016-04-19 16:43:12 -04001381 return true;
Shannon Woods53a94a82014-06-24 15:20:36 -04001382 }
Corentin Walleza2257da2016-04-19 16:43:12 -04001383
1384 return false;
Shannon Woods53a94a82014-06-24 15:20:36 -04001385}
1386
Yunchao Hea336b902017-08-02 16:05:21 +08001387void State::setProgramPipelineBinding(const Context *context, ProgramPipeline *pipeline)
1388{
1389 mProgramPipeline.set(context, pipeline);
1390}
1391
1392void State::detachProgramPipeline(const Context *context, GLuint pipeline)
1393{
1394 mProgramPipeline.set(context, nullptr);
1395}
1396
Corentin Wallezad3ae902018-03-09 13:40:42 -05001397bool State::isQueryActive(QueryType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001398{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001399 const Query *query = mActiveQueries[type].get();
1400 if (query != nullptr)
Shannon Woods53a94a82014-06-24 15:20:36 -04001401 {
Corentin Wallezad3ae902018-03-09 13:40:42 -05001402 return true;
1403 }
1404
1405 QueryType alternativeType;
1406 if (GetAlternativeQueryType(type, &alternativeType))
1407 {
1408 query = mActiveQueries[alternativeType].get();
1409 return query != nullptr;
Ian Ewell3ffd78b2016-01-22 16:09:42 -05001410 }
1411
1412 return false;
1413}
1414
1415bool State::isQueryActive(Query *query) const
1416{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001417 for (auto &queryPointer : mActiveQueries)
Ian Ewell3ffd78b2016-01-22 16:09:42 -05001418 {
Corentin Wallezad3ae902018-03-09 13:40:42 -05001419 if (queryPointer.get() == query)
Shannon Woods53a94a82014-06-24 15:20:36 -04001420 {
1421 return true;
1422 }
1423 }
1424
1425 return false;
1426}
1427
Corentin Wallezad3ae902018-03-09 13:40:42 -05001428void State::setActiveQuery(const Context *context, QueryType type, Query *query)
Shannon Woods53a94a82014-06-24 15:20:36 -04001429{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001430 mActiveQueries[type].set(context, query);
Shannon Woods53a94a82014-06-24 15:20:36 -04001431}
1432
Corentin Wallezad3ae902018-03-09 13:40:42 -05001433GLuint State::getActiveQueryId(QueryType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001434{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001435 const Query *query = getActiveQuery(type);
Shannon Woods53a94a82014-06-24 15:20:36 -04001436 return (query ? query->id() : 0u);
1437}
1438
Corentin Wallezad3ae902018-03-09 13:40:42 -05001439Query *State::getActiveQuery(QueryType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001440{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001441 return mActiveQueries[type].get();
Shannon Woods53a94a82014-06-24 15:20:36 -04001442}
1443
Corentin Wallez336129f2017-10-17 15:55:40 -04001444void State::setBufferBinding(const Context *context, BufferBinding target, Buffer *buffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001445{
Corentin Wallez336129f2017-10-17 15:55:40 -04001446 switch (target)
1447 {
1448 case BufferBinding::PixelPack:
Jamie Madillfcfd3382018-09-15 22:30:50 -04001449 UpdateNonTFBufferBinding(context, &mBoundBuffers[target], buffer);
Corentin Wallez336129f2017-10-17 15:55:40 -04001450 mDirtyBits.set(DIRTY_BIT_PACK_BUFFER_BINDING);
1451 break;
1452 case BufferBinding::PixelUnpack:
Jamie Madillfcfd3382018-09-15 22:30:50 -04001453 UpdateNonTFBufferBinding(context, &mBoundBuffers[target], buffer);
Corentin Wallez336129f2017-10-17 15:55:40 -04001454 mDirtyBits.set(DIRTY_BIT_UNPACK_BUFFER_BINDING);
1455 break;
1456 case BufferBinding::DrawIndirect:
Jamie Madillfcfd3382018-09-15 22:30:50 -04001457 UpdateNonTFBufferBinding(context, &mBoundBuffers[target], buffer);
Corentin Wallez336129f2017-10-17 15:55:40 -04001458 mDirtyBits.set(DIRTY_BIT_DRAW_INDIRECT_BUFFER_BINDING);
1459 break;
Qin Jiajiaa98a2812017-11-30 18:12:06 +08001460 case BufferBinding::DispatchIndirect:
Jamie Madillfcfd3382018-09-15 22:30:50 -04001461 UpdateNonTFBufferBinding(context, &mBoundBuffers[target], buffer);
Qin Jiajiaa98a2812017-11-30 18:12:06 +08001462 mDirtyBits.set(DIRTY_BIT_DISPATCH_INDIRECT_BUFFER_BINDING);
1463 break;
Corentin Wallez336129f2017-10-17 15:55:40 -04001464 case BufferBinding::ElementArray:
1465 getVertexArray()->setElementArrayBuffer(context, buffer);
1466 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1467 break;
Xinghua Cao10a4d432017-11-28 14:46:26 +08001468 case BufferBinding::ShaderStorage:
Jamie Madillfcfd3382018-09-15 22:30:50 -04001469 UpdateNonTFBufferBinding(context, &mBoundBuffers[target], buffer);
Xinghua Cao10a4d432017-11-28 14:46:26 +08001470 mDirtyBits.set(DIRTY_BIT_SHADER_STORAGE_BUFFER_BINDING);
1471 break;
jchen1099118c12018-09-10 16:28:51 +08001472 case BufferBinding::Uniform:
1473 UpdateBufferBinding(context, &mBoundBuffers[target], buffer, target);
1474 mDirtyBits.set(DIRTY_BIT_UNIFORM_BUFFER_BINDINGS);
1475 break;
1476 case BufferBinding::AtomicCounter:
1477 UpdateBufferBinding(context, &mBoundBuffers[target], buffer, target);
1478 mDirtyBits.set(DIRTY_BIT_ATOMIC_COUNTER_BUFFER_BINDING);
1479 break;
Corentin Wallez336129f2017-10-17 15:55:40 -04001480 default:
Jamie Madillbf5177d2018-08-21 12:58:20 -04001481 UpdateBufferBinding(context, &mBoundBuffers[target], buffer, target);
Corentin Wallez336129f2017-10-17 15:55:40 -04001482 break;
1483 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001484}
James Darpiniane8a93c62018-01-04 18:02:24 -08001485
Corentin Wallez336129f2017-10-17 15:55:40 -04001486void State::setIndexedBufferBinding(const Context *context,
1487 BufferBinding target,
1488 GLuint index,
1489 Buffer *buffer,
1490 GLintptr offset,
1491 GLsizeiptr size)
Jiajia Qin9d7d0b12016-11-29 16:30:31 +08001492{
Corentin Wallez336129f2017-10-17 15:55:40 -04001493 setBufferBinding(context, target, buffer);
Jiajia Qin9d7d0b12016-11-29 16:30:31 +08001494
Corentin Wallez336129f2017-10-17 15:55:40 -04001495 switch (target)
1496 {
1497 case BufferBinding::TransformFeedback:
1498 mTransformFeedback->bindIndexedBuffer(context, index, buffer, offset, size);
James Darpiniane8a93c62018-01-04 18:02:24 -08001499 setBufferBinding(context, target, buffer);
Corentin Wallez336129f2017-10-17 15:55:40 -04001500 break;
1501 case BufferBinding::Uniform:
Jamie Madillbf5177d2018-08-21 12:58:20 -04001502 UpdateIndexedBufferBinding(context, &mUniformBuffers[index], buffer, target, offset,
1503 size);
Corentin Wallez336129f2017-10-17 15:55:40 -04001504 break;
1505 case BufferBinding::AtomicCounter:
Jamie Madillbf5177d2018-08-21 12:58:20 -04001506 UpdateIndexedBufferBinding(context, &mAtomicCounterBuffers[index], buffer, target,
1507 offset, size);
Corentin Wallez336129f2017-10-17 15:55:40 -04001508 break;
1509 case BufferBinding::ShaderStorage:
Jamie Madillbf5177d2018-08-21 12:58:20 -04001510 UpdateIndexedBufferBinding(context, &mShaderStorageBuffers[index], buffer, target,
1511 offset, size);
Corentin Wallez336129f2017-10-17 15:55:40 -04001512 break;
1513 default:
1514 UNREACHABLE();
1515 break;
1516 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001517}
1518
Geoff Lang5d124a62015-09-15 13:03:27 -04001519const OffsetBindingPointer<Buffer> &State::getIndexedUniformBuffer(size_t index) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001520{
Shannon Woodsf3acaf92014-09-23 18:07:11 -04001521 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
Geoff Lang5d124a62015-09-15 13:03:27 -04001522 return mUniformBuffers[index];
Gregoire Payen de La Garanderie68694e92015-03-24 14:03:37 +00001523}
1524
Jiajia Qin6eafb042016-12-27 17:04:07 +08001525const OffsetBindingPointer<Buffer> &State::getIndexedAtomicCounterBuffer(size_t index) const
1526{
1527 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
1528 return mAtomicCounterBuffers[index];
1529}
1530
Jiajia Qinf546e7d2017-03-27 14:12:59 +08001531const OffsetBindingPointer<Buffer> &State::getIndexedShaderStorageBuffer(size_t index) const
1532{
1533 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
1534 return mShaderStorageBuffers[index];
1535}
1536
Corentin Wallez336129f2017-10-17 15:55:40 -04001537Buffer *State::getTargetBuffer(BufferBinding target) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001538{
1539 switch (target)
1540 {
Corentin Wallez336129f2017-10-17 15:55:40 -04001541 case BufferBinding::ElementArray:
1542 return getVertexArray()->getElementArrayBuffer().get();
Corentin Wallez336129f2017-10-17 15:55:40 -04001543 default:
1544 return mBoundBuffers[target].get();
Shannon Woods53a94a82014-06-24 15:20:36 -04001545 }
1546}
1547
James Darpinian4d9d4832018-03-13 12:43:28 -07001548void State::detachBuffer(const Context *context, const Buffer *buffer)
Yuly Novikov5807a532015-12-03 13:01:22 -05001549{
James Darpinian4d9d4832018-03-13 12:43:28 -07001550 if (!buffer->isBound())
1551 {
1552 return;
1553 }
1554 GLuint bufferName = buffer->id();
James Darpiniane8a93c62018-01-04 18:02:24 -08001555 for (auto target : angle::AllEnums<BufferBinding>())
Yuly Novikov5807a532015-12-03 13:01:22 -05001556 {
James Darpiniane8a93c62018-01-04 18:02:24 -08001557 if (mBoundBuffers[target].id() == bufferName)
Yuly Novikov5807a532015-12-03 13:01:22 -05001558 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001559 UpdateBufferBinding(context, &mBoundBuffers[target], nullptr, target);
Yuly Novikov5807a532015-12-03 13:01:22 -05001560 }
1561 }
1562
1563 TransformFeedback *curTransformFeedback = getCurrentTransformFeedback();
1564 if (curTransformFeedback)
1565 {
Jamie Madill4928b7c2017-06-20 12:57:39 -04001566 curTransformFeedback->detachBuffer(context, bufferName);
Yuly Novikov5807a532015-12-03 13:01:22 -05001567 }
1568
Jamie Madill4928b7c2017-06-20 12:57:39 -04001569 getVertexArray()->detachBuffer(context, bufferName);
James Darpiniane8a93c62018-01-04 18:02:24 -08001570
1571 for (auto &buf : mUniformBuffers)
1572 {
1573 if (buf.id() == bufferName)
1574 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001575 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::Uniform, 0, 0);
James Darpiniane8a93c62018-01-04 18:02:24 -08001576 }
1577 }
1578
1579 for (auto &buf : mAtomicCounterBuffers)
1580 {
1581 if (buf.id() == bufferName)
1582 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001583 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::AtomicCounter, 0, 0);
James Darpiniane8a93c62018-01-04 18:02:24 -08001584 }
1585 }
1586
1587 for (auto &buf : mShaderStorageBuffers)
1588 {
1589 if (buf.id() == bufferName)
1590 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001591 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::ShaderStorage, 0, 0);
James Darpiniane8a93c62018-01-04 18:02:24 -08001592 }
1593 }
Yuly Novikov5807a532015-12-03 13:01:22 -05001594}
1595
Shannon Woods53a94a82014-06-24 15:20:36 -04001596void State::setEnableVertexAttribArray(unsigned int attribNum, bool enabled)
1597{
1598 getVertexArray()->enableAttribute(attribNum, enabled);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001599 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001600}
1601
1602void State::setVertexAttribf(GLuint index, const GLfloat values[4])
1603{
Shannon Woods23e05002014-09-22 19:07:27 -04001604 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001605 mVertexAttribCurrentValues[index].setFloatValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001606 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1607 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001608 mCurrentValuesTypeMask.setIndex(GL_FLOAT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001609}
1610
1611void State::setVertexAttribu(GLuint index, const GLuint values[4])
1612{
Shannon Woods23e05002014-09-22 19:07:27 -04001613 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001614 mVertexAttribCurrentValues[index].setUnsignedIntValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001615 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1616 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001617 mCurrentValuesTypeMask.setIndex(GL_UNSIGNED_INT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001618}
1619
1620void State::setVertexAttribi(GLuint index, const GLint values[4])
1621{
Shannon Woods23e05002014-09-22 19:07:27 -04001622 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001623 mVertexAttribCurrentValues[index].setIntValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001624 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1625 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001626 mCurrentValuesTypeMask.setIndex(GL_INT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001627}
1628
Shaodde78e82017-05-22 14:13:27 +08001629void State::setVertexAttribPointer(const Context *context,
1630 unsigned int attribNum,
1631 Buffer *boundBuffer,
1632 GLint size,
1633 GLenum type,
1634 bool normalized,
1635 bool pureInteger,
1636 GLsizei stride,
1637 const void *pointer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001638{
Shaodde78e82017-05-22 14:13:27 +08001639 getVertexArray()->setVertexAttribPointer(context, attribNum, boundBuffer, size, type,
1640 normalized, pureInteger, stride, pointer);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001641 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Jamie Madill0b9e9032015-08-17 11:51:52 +00001642}
1643
Shaodde78e82017-05-22 14:13:27 +08001644void State::setVertexAttribDivisor(const Context *context, GLuint index, GLuint divisor)
Jamie Madill0b9e9032015-08-17 11:51:52 +00001645{
Shaodde78e82017-05-22 14:13:27 +08001646 getVertexArray()->setVertexAttribDivisor(context, index, divisor);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001647 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001648}
1649
Jamie Madill6de51852017-04-12 09:53:01 -04001650const VertexAttribCurrentValueData &State::getVertexAttribCurrentValue(size_t attribNum) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001651{
Jamie Madill6de51852017-04-12 09:53:01 -04001652 ASSERT(attribNum < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001653 return mVertexAttribCurrentValues[attribNum];
1654}
1655
Jamie Madillcac94a92017-11-10 10:09:32 -05001656const std::vector<VertexAttribCurrentValueData> &State::getVertexAttribCurrentValues() const
1657{
1658 return mVertexAttribCurrentValues;
1659}
1660
Shannon Woods53a94a82014-06-24 15:20:36 -04001661const void *State::getVertexAttribPointer(unsigned int attribNum) const
1662{
1663 return getVertexArray()->getVertexAttribute(attribNum).pointer;
1664}
1665
1666void State::setPackAlignment(GLint alignment)
1667{
1668 mPack.alignment = alignment;
Jamie Madillc67323a2017-11-02 23:11:41 -04001669 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001670}
1671
1672GLint State::getPackAlignment() const
1673{
1674 return mPack.alignment;
1675}
1676
1677void State::setPackReverseRowOrder(bool reverseRowOrder)
1678{
1679 mPack.reverseRowOrder = reverseRowOrder;
Jamie Madillc67323a2017-11-02 23:11:41 -04001680 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001681}
1682
1683bool State::getPackReverseRowOrder() const
1684{
1685 return mPack.reverseRowOrder;
1686}
1687
Minmin Gongadff67b2015-10-14 10:34:45 -04001688void State::setPackRowLength(GLint rowLength)
1689{
1690 mPack.rowLength = rowLength;
Jamie Madillc67323a2017-11-02 23:11:41 -04001691 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001692}
1693
1694GLint State::getPackRowLength() const
1695{
1696 return mPack.rowLength;
1697}
1698
1699void State::setPackSkipRows(GLint skipRows)
1700{
1701 mPack.skipRows = skipRows;
Jamie Madillc67323a2017-11-02 23:11:41 -04001702 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001703}
1704
1705GLint State::getPackSkipRows() const
1706{
1707 return mPack.skipRows;
1708}
1709
1710void State::setPackSkipPixels(GLint skipPixels)
1711{
1712 mPack.skipPixels = skipPixels;
Jamie Madillc67323a2017-11-02 23:11:41 -04001713 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001714}
1715
1716GLint State::getPackSkipPixels() const
1717{
1718 return mPack.skipPixels;
1719}
1720
Shannon Woods53a94a82014-06-24 15:20:36 -04001721const PixelPackState &State::getPackState() const
1722{
1723 return mPack;
1724}
1725
Jamie Madill87de3622015-03-16 10:41:44 -04001726PixelPackState &State::getPackState()
1727{
1728 return mPack;
1729}
1730
Shannon Woods53a94a82014-06-24 15:20:36 -04001731void State::setUnpackAlignment(GLint alignment)
1732{
1733 mUnpack.alignment = alignment;
Jamie Madillc67323a2017-11-02 23:11:41 -04001734 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001735}
1736
1737GLint State::getUnpackAlignment() const
1738{
1739 return mUnpack.alignment;
1740}
1741
Minmin Gongb8aee3b2015-01-27 14:42:36 -08001742void State::setUnpackRowLength(GLint rowLength)
1743{
1744 mUnpack.rowLength = rowLength;
Jamie Madillc67323a2017-11-02 23:11:41 -04001745 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongb8aee3b2015-01-27 14:42:36 -08001746}
1747
1748GLint State::getUnpackRowLength() const
1749{
1750 return mUnpack.rowLength;
1751}
1752
Minmin Gongadff67b2015-10-14 10:34:45 -04001753void State::setUnpackImageHeight(GLint imageHeight)
1754{
1755 mUnpack.imageHeight = imageHeight;
Jamie Madillc67323a2017-11-02 23:11:41 -04001756 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001757}
1758
1759GLint State::getUnpackImageHeight() const
1760{
1761 return mUnpack.imageHeight;
1762}
1763
1764void State::setUnpackSkipImages(GLint skipImages)
1765{
1766 mUnpack.skipImages = skipImages;
Jamie Madillc67323a2017-11-02 23:11:41 -04001767 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001768}
1769
1770GLint State::getUnpackSkipImages() const
1771{
1772 return mUnpack.skipImages;
1773}
1774
1775void State::setUnpackSkipRows(GLint skipRows)
1776{
1777 mUnpack.skipRows = skipRows;
Jamie Madillc67323a2017-11-02 23:11:41 -04001778 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001779}
1780
1781GLint State::getUnpackSkipRows() const
1782{
1783 return mUnpack.skipRows;
1784}
1785
1786void State::setUnpackSkipPixels(GLint skipPixels)
1787{
1788 mUnpack.skipPixels = skipPixels;
Jamie Madillc67323a2017-11-02 23:11:41 -04001789 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001790}
1791
1792GLint State::getUnpackSkipPixels() const
1793{
1794 return mUnpack.skipPixels;
1795}
1796
Shannon Woods53a94a82014-06-24 15:20:36 -04001797const PixelUnpackState &State::getUnpackState() const
1798{
1799 return mUnpack;
1800}
1801
Jamie Madill67102f02015-03-16 10:41:42 -04001802PixelUnpackState &State::getUnpackState()
1803{
1804 return mUnpack;
1805}
1806
Geoff Lang70d0f492015-12-10 17:45:46 -05001807const Debug &State::getDebug() const
1808{
1809 return mDebug;
1810}
1811
1812Debug &State::getDebug()
1813{
1814 return mDebug;
1815}
1816
Sami Väisänena797e062016-05-12 15:23:40 +03001817void State::setCoverageModulation(GLenum components)
1818{
1819 mCoverageModulation = components;
1820 mDirtyBits.set(DIRTY_BIT_COVERAGE_MODULATION);
1821}
1822
1823GLenum State::getCoverageModulation() const
1824{
1825 return mCoverageModulation;
1826}
1827
Sami Väisänene45e53b2016-05-25 10:36:04 +03001828void State::loadPathRenderingMatrix(GLenum matrixMode, const GLfloat *matrix)
1829{
1830 if (matrixMode == GL_PATH_MODELVIEW_CHROMIUM)
1831 {
1832 memcpy(mPathMatrixMV, matrix, 16 * sizeof(GLfloat));
jchen10bb2f2c42018-09-16 09:47:38 +08001833 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING);
Sami Väisänene45e53b2016-05-25 10:36:04 +03001834 }
1835 else if (matrixMode == GL_PATH_PROJECTION_CHROMIUM)
1836 {
1837 memcpy(mPathMatrixProj, matrix, 16 * sizeof(GLfloat));
jchen10bb2f2c42018-09-16 09:47:38 +08001838 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING);
Sami Väisänene45e53b2016-05-25 10:36:04 +03001839 }
1840 else
1841 {
1842 UNREACHABLE();
1843 }
1844}
1845
1846const GLfloat *State::getPathRenderingMatrix(GLenum which) const
1847{
1848 if (which == GL_PATH_MODELVIEW_MATRIX_CHROMIUM)
1849 {
1850 return mPathMatrixMV;
1851 }
1852 else if (which == GL_PATH_PROJECTION_MATRIX_CHROMIUM)
1853 {
1854 return mPathMatrixProj;
1855 }
1856
1857 UNREACHABLE();
1858 return nullptr;
1859}
1860
1861void State::setPathStencilFunc(GLenum func, GLint ref, GLuint mask)
1862{
1863 mPathStencilFunc = func;
1864 mPathStencilRef = ref;
1865 mPathStencilMask = mask;
jchen10bb2f2c42018-09-16 09:47:38 +08001866 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING);
Sami Väisänene45e53b2016-05-25 10:36:04 +03001867}
1868
1869GLenum State::getPathStencilFunc() const
1870{
1871 return mPathStencilFunc;
1872}
1873
1874GLint State::getPathStencilRef() const
1875{
1876 return mPathStencilRef;
1877}
1878
1879GLuint State::getPathStencilMask() const
1880{
1881 return mPathStencilMask;
1882}
1883
Geoff Lang1d2c41d2016-10-19 16:14:46 -07001884void State::setFramebufferSRGB(bool sRGB)
1885{
1886 mFramebufferSRGB = sRGB;
1887 mDirtyBits.set(DIRTY_BIT_FRAMEBUFFER_SRGB);
1888}
1889
1890bool State::getFramebufferSRGB() const
1891{
1892 return mFramebufferSRGB;
1893}
1894
jchen1082af6202018-06-22 10:59:52 +08001895void State::setMaxShaderCompilerThreads(GLuint count)
1896{
1897 mMaxShaderCompilerThreads = count;
1898}
1899
1900GLuint State::getMaxShaderCompilerThreads() const
1901{
1902 return mMaxShaderCompilerThreads;
1903}
1904
Shannon Woods53a94a82014-06-24 15:20:36 -04001905void State::getBooleanv(GLenum pname, GLboolean *params)
1906{
1907 switch (pname)
1908 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001909 case GL_SAMPLE_COVERAGE_INVERT:
1910 *params = mSampleCoverageInvert;
1911 break;
1912 case GL_DEPTH_WRITEMASK:
1913 *params = mDepthStencil.depthMask;
1914 break;
1915 case GL_COLOR_WRITEMASK:
1916 params[0] = mBlend.colorMaskRed;
1917 params[1] = mBlend.colorMaskGreen;
1918 params[2] = mBlend.colorMaskBlue;
1919 params[3] = mBlend.colorMaskAlpha;
1920 break;
1921 case GL_CULL_FACE:
1922 *params = mRasterizer.cullFace;
1923 break;
1924 case GL_POLYGON_OFFSET_FILL:
1925 *params = mRasterizer.polygonOffsetFill;
1926 break;
1927 case GL_SAMPLE_ALPHA_TO_COVERAGE:
1928 *params = mBlend.sampleAlphaToCoverage;
1929 break;
1930 case GL_SAMPLE_COVERAGE:
1931 *params = mSampleCoverage;
1932 break;
1933 case GL_SAMPLE_MASK:
1934 *params = mSampleMask;
1935 break;
1936 case GL_SCISSOR_TEST:
1937 *params = mScissorTest;
1938 break;
1939 case GL_STENCIL_TEST:
1940 *params = mDepthStencil.stencilTest;
1941 break;
1942 case GL_DEPTH_TEST:
1943 *params = mDepthStencil.depthTest;
1944 break;
1945 case GL_BLEND:
1946 *params = mBlend.blend;
1947 break;
1948 case GL_DITHER:
1949 *params = mBlend.dither;
1950 break;
1951 case GL_TRANSFORM_FEEDBACK_ACTIVE:
1952 *params = getCurrentTransformFeedback()->isActive() ? GL_TRUE : GL_FALSE;
1953 break;
1954 case GL_TRANSFORM_FEEDBACK_PAUSED:
1955 *params = getCurrentTransformFeedback()->isPaused() ? GL_TRUE : GL_FALSE;
1956 break;
1957 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
1958 *params = mPrimitiveRestart;
1959 break;
1960 case GL_RASTERIZER_DISCARD:
1961 *params = isRasterizerDiscardEnabled() ? GL_TRUE : GL_FALSE;
1962 break;
1963 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
1964 *params = mDebug.isOutputSynchronous() ? GL_TRUE : GL_FALSE;
1965 break;
1966 case GL_DEBUG_OUTPUT:
1967 *params = mDebug.isOutputEnabled() ? GL_TRUE : GL_FALSE;
1968 break;
1969 case GL_MULTISAMPLE_EXT:
1970 *params = mMultiSampling;
1971 break;
1972 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
1973 *params = mSampleAlphaToOne;
1974 break;
1975 case GL_BIND_GENERATES_RESOURCE_CHROMIUM:
1976 *params = isBindGeneratesResourceEnabled() ? GL_TRUE : GL_FALSE;
1977 break;
1978 case GL_CLIENT_ARRAYS_ANGLE:
1979 *params = areClientArraysEnabled() ? GL_TRUE : GL_FALSE;
1980 break;
1981 case GL_FRAMEBUFFER_SRGB_EXT:
1982 *params = getFramebufferSRGB() ? GL_TRUE : GL_FALSE;
1983 break;
1984 case GL_ROBUST_RESOURCE_INITIALIZATION_ANGLE:
1985 *params = mRobustResourceInit ? GL_TRUE : GL_FALSE;
1986 break;
1987 case GL_PROGRAM_CACHE_ENABLED_ANGLE:
1988 *params = mProgramBinaryCacheEnabled ? GL_TRUE : GL_FALSE;
1989 break;
Lingfeng Yangd0febe72018-05-17 22:36:52 -07001990 case GL_LIGHT_MODEL_TWO_SIDE:
1991 *params = IsLightModelTwoSided(&mGLES1State);
1992 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001993 default:
1994 UNREACHABLE();
1995 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04001996 }
1997}
1998
1999void State::getFloatv(GLenum pname, GLfloat *params)
2000{
2001 // Please note: DEPTH_CLEAR_VALUE is included in our internal getFloatv implementation
2002 // because it is stored as a float, despite the fact that the GL ES 2.0 spec names
2003 // GetIntegerv as its native query function. As it would require conversion in any
2004 // case, this should make no difference to the calling application.
2005 switch (pname)
2006 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002007 case GL_LINE_WIDTH:
2008 *params = mLineWidth;
2009 break;
2010 case GL_SAMPLE_COVERAGE_VALUE:
2011 *params = mSampleCoverageValue;
2012 break;
2013 case GL_DEPTH_CLEAR_VALUE:
2014 *params = mDepthClearValue;
2015 break;
2016 case GL_POLYGON_OFFSET_FACTOR:
2017 *params = mRasterizer.polygonOffsetFactor;
2018 break;
2019 case GL_POLYGON_OFFSET_UNITS:
2020 *params = mRasterizer.polygonOffsetUnits;
2021 break;
2022 case GL_DEPTH_RANGE:
2023 params[0] = mNearZ;
2024 params[1] = mFarZ;
2025 break;
2026 case GL_COLOR_CLEAR_VALUE:
2027 params[0] = mColorClearValue.red;
2028 params[1] = mColorClearValue.green;
2029 params[2] = mColorClearValue.blue;
2030 params[3] = mColorClearValue.alpha;
2031 break;
2032 case GL_BLEND_COLOR:
2033 params[0] = mBlendColor.red;
2034 params[1] = mBlendColor.green;
2035 params[2] = mBlendColor.blue;
2036 params[3] = mBlendColor.alpha;
2037 break;
2038 case GL_MULTISAMPLE_EXT:
2039 *params = static_cast<GLfloat>(mMultiSampling);
2040 break;
2041 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
2042 *params = static_cast<GLfloat>(mSampleAlphaToOne);
2043 break;
2044 case GL_COVERAGE_MODULATION_CHROMIUM:
2045 params[0] = static_cast<GLfloat>(mCoverageModulation);
2046 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -07002047 case GL_ALPHA_TEST_REF:
2048 *params = mGLES1State.mAlphaTestRef;
2049 break;
Lingfeng Yanga43994c2018-03-29 07:21:41 -07002050 case GL_CURRENT_COLOR:
2051 {
2052 const auto &color = mGLES1State.mCurrentColor;
2053 params[0] = color.red;
2054 params[1] = color.green;
2055 params[2] = color.blue;
2056 params[3] = color.alpha;
2057 break;
2058 }
Lingfeng Yang5a7e61b2018-03-29 16:50:32 -07002059 case GL_CURRENT_NORMAL:
2060 {
2061 const auto &normal = mGLES1State.mCurrentNormal;
2062 params[0] = normal[0];
2063 params[1] = normal[1];
2064 params[2] = normal[2];
2065 break;
2066 }
Lingfeng Yang038dd532018-03-29 17:31:52 -07002067 case GL_CURRENT_TEXTURE_COORDS:
2068 {
2069 const auto &texcoord = mGLES1State.mCurrentTextureCoords[mActiveSampler];
2070 params[0] = texcoord.s;
2071 params[1] = texcoord.t;
2072 params[2] = texcoord.r;
2073 params[3] = texcoord.q;
2074 break;
2075 }
Lingfeng Yang3a41af62018-04-09 07:28:56 -07002076 case GL_MODELVIEW_MATRIX:
2077 memcpy(params, mGLES1State.mModelviewMatrices.back().data(), 16 * sizeof(GLfloat));
2078 break;
2079 case GL_PROJECTION_MATRIX:
2080 memcpy(params, mGLES1State.mProjectionMatrices.back().data(), 16 * sizeof(GLfloat));
2081 break;
2082 case GL_TEXTURE_MATRIX:
2083 memcpy(params, mGLES1State.mTextureMatrices[mActiveSampler].back().data(),
2084 16 * sizeof(GLfloat));
2085 break;
Lingfeng Yangd0febe72018-05-17 22:36:52 -07002086 case GL_LIGHT_MODEL_AMBIENT:
2087 GetLightModelParameters(&mGLES1State, pname, params);
2088 break;
Lingfeng Yang7ba3f422018-06-01 09:43:04 -07002089 case GL_FOG_MODE:
2090 case GL_FOG_DENSITY:
2091 case GL_FOG_START:
2092 case GL_FOG_END:
2093 case GL_FOG_COLOR:
2094 GetFogParameters(&mGLES1State, pname, params);
2095 break;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -07002096 case GL_POINT_SIZE:
2097 GetPointSize(&mGLES1State, params);
2098 break;
2099 case GL_POINT_SIZE_MIN:
2100 case GL_POINT_SIZE_MAX:
2101 case GL_POINT_FADE_THRESHOLD_SIZE:
2102 case GL_POINT_DISTANCE_ATTENUATION:
2103 GetPointParameter(&mGLES1State, FromGLenum<PointParameter>(pname), params);
2104 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002105 default:
2106 UNREACHABLE();
2107 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002108 }
2109}
2110
Jamie Madille98b1b52018-03-08 09:47:23 -05002111Error State::getIntegerv(const Context *context, GLenum pname, GLint *params)
Shannon Woods53a94a82014-06-24 15:20:36 -04002112{
2113 if (pname >= GL_DRAW_BUFFER0_EXT && pname <= GL_DRAW_BUFFER15_EXT)
2114 {
2115 unsigned int colorAttachment = (pname - GL_DRAW_BUFFER0_EXT);
Shannon Woods2df6a602014-09-26 16:12:07 -04002116 ASSERT(colorAttachment < mMaxDrawBuffers);
Shannon Woods53a94a82014-06-24 15:20:36 -04002117 Framebuffer *framebuffer = mDrawFramebuffer;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002118 *params = framebuffer->getDrawBufferState(colorAttachment);
Jamie Madille98b1b52018-03-08 09:47:23 -05002119 return NoError();
Shannon Woods53a94a82014-06-24 15:20:36 -04002120 }
2121
2122 // Please note: DEPTH_CLEAR_VALUE is not included in our internal getIntegerv implementation
2123 // because it is stored as a float, despite the fact that the GL ES 2.0 spec names
2124 // GetIntegerv as its native query function. As it would require conversion in any
2125 // case, this should make no difference to the calling application. You may find it in
2126 // State::getFloatv.
2127 switch (pname)
2128 {
Corentin Wallez336129f2017-10-17 15:55:40 -04002129 case GL_ARRAY_BUFFER_BINDING:
2130 *params = mBoundBuffers[BufferBinding::Array].id();
2131 break;
2132 case GL_DRAW_INDIRECT_BUFFER_BINDING:
2133 *params = mBoundBuffers[BufferBinding::DrawIndirect].id();
2134 break;
2135 case GL_ELEMENT_ARRAY_BUFFER_BINDING:
2136 *params = getVertexArray()->getElementArrayBuffer().id();
2137 break;
Jamie Madill690c8eb2018-03-12 15:20:03 -04002138 case GL_DRAW_FRAMEBUFFER_BINDING:
2139 static_assert(GL_DRAW_FRAMEBUFFER_BINDING == GL_DRAW_FRAMEBUFFER_BINDING_ANGLE,
2140 "Enum mismatch");
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002141 *params = mDrawFramebuffer->id();
2142 break;
Jamie Madill690c8eb2018-03-12 15:20:03 -04002143 case GL_READ_FRAMEBUFFER_BINDING:
2144 static_assert(GL_READ_FRAMEBUFFER_BINDING == GL_READ_FRAMEBUFFER_BINDING_ANGLE,
2145 "Enum mismatch");
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002146 *params = mReadFramebuffer->id();
2147 break;
2148 case GL_RENDERBUFFER_BINDING:
2149 *params = mRenderbuffer.id();
2150 break;
2151 case GL_VERTEX_ARRAY_BINDING:
2152 *params = mVertexArray->id();
2153 break;
2154 case GL_CURRENT_PROGRAM:
2155 *params = mProgram ? mProgram->id() : 0;
2156 break;
2157 case GL_PACK_ALIGNMENT:
2158 *params = mPack.alignment;
2159 break;
2160 case GL_PACK_REVERSE_ROW_ORDER_ANGLE:
2161 *params = mPack.reverseRowOrder;
2162 break;
2163 case GL_PACK_ROW_LENGTH:
2164 *params = mPack.rowLength;
2165 break;
2166 case GL_PACK_SKIP_ROWS:
2167 *params = mPack.skipRows;
2168 break;
2169 case GL_PACK_SKIP_PIXELS:
2170 *params = mPack.skipPixels;
2171 break;
2172 case GL_UNPACK_ALIGNMENT:
2173 *params = mUnpack.alignment;
2174 break;
2175 case GL_UNPACK_ROW_LENGTH:
2176 *params = mUnpack.rowLength;
2177 break;
2178 case GL_UNPACK_IMAGE_HEIGHT:
2179 *params = mUnpack.imageHeight;
2180 break;
2181 case GL_UNPACK_SKIP_IMAGES:
2182 *params = mUnpack.skipImages;
2183 break;
2184 case GL_UNPACK_SKIP_ROWS:
2185 *params = mUnpack.skipRows;
2186 break;
2187 case GL_UNPACK_SKIP_PIXELS:
2188 *params = mUnpack.skipPixels;
2189 break;
2190 case GL_GENERATE_MIPMAP_HINT:
2191 *params = mGenerateMipmapHint;
2192 break;
2193 case GL_FRAGMENT_SHADER_DERIVATIVE_HINT_OES:
2194 *params = mFragmentShaderDerivativeHint;
2195 break;
2196 case GL_ACTIVE_TEXTURE:
2197 *params = (static_cast<GLint>(mActiveSampler) + GL_TEXTURE0);
2198 break;
2199 case GL_STENCIL_FUNC:
2200 *params = mDepthStencil.stencilFunc;
2201 break;
2202 case GL_STENCIL_REF:
2203 *params = mStencilRef;
2204 break;
2205 case GL_STENCIL_VALUE_MASK:
2206 *params = CastMaskValue(context, mDepthStencil.stencilMask);
2207 break;
2208 case GL_STENCIL_BACK_FUNC:
2209 *params = mDepthStencil.stencilBackFunc;
2210 break;
2211 case GL_STENCIL_BACK_REF:
2212 *params = mStencilBackRef;
2213 break;
2214 case GL_STENCIL_BACK_VALUE_MASK:
2215 *params = CastMaskValue(context, mDepthStencil.stencilBackMask);
2216 break;
2217 case GL_STENCIL_FAIL:
2218 *params = mDepthStencil.stencilFail;
2219 break;
2220 case GL_STENCIL_PASS_DEPTH_FAIL:
2221 *params = mDepthStencil.stencilPassDepthFail;
2222 break;
2223 case GL_STENCIL_PASS_DEPTH_PASS:
2224 *params = mDepthStencil.stencilPassDepthPass;
2225 break;
2226 case GL_STENCIL_BACK_FAIL:
2227 *params = mDepthStencil.stencilBackFail;
2228 break;
2229 case GL_STENCIL_BACK_PASS_DEPTH_FAIL:
2230 *params = mDepthStencil.stencilBackPassDepthFail;
2231 break;
2232 case GL_STENCIL_BACK_PASS_DEPTH_PASS:
2233 *params = mDepthStencil.stencilBackPassDepthPass;
2234 break;
2235 case GL_DEPTH_FUNC:
2236 *params = mDepthStencil.depthFunc;
2237 break;
2238 case GL_BLEND_SRC_RGB:
2239 *params = mBlend.sourceBlendRGB;
2240 break;
2241 case GL_BLEND_SRC_ALPHA:
2242 *params = mBlend.sourceBlendAlpha;
2243 break;
2244 case GL_BLEND_DST_RGB:
2245 *params = mBlend.destBlendRGB;
2246 break;
2247 case GL_BLEND_DST_ALPHA:
2248 *params = mBlend.destBlendAlpha;
2249 break;
2250 case GL_BLEND_EQUATION_RGB:
2251 *params = mBlend.blendEquationRGB;
2252 break;
2253 case GL_BLEND_EQUATION_ALPHA:
2254 *params = mBlend.blendEquationAlpha;
2255 break;
2256 case GL_STENCIL_WRITEMASK:
2257 *params = CastMaskValue(context, mDepthStencil.stencilWritemask);
2258 break;
2259 case GL_STENCIL_BACK_WRITEMASK:
2260 *params = CastMaskValue(context, mDepthStencil.stencilBackWritemask);
2261 break;
2262 case GL_STENCIL_CLEAR_VALUE:
2263 *params = mStencilClearValue;
2264 break;
2265 case GL_IMPLEMENTATION_COLOR_READ_TYPE:
Jamie Madill690c8eb2018-03-12 15:20:03 -04002266 ANGLE_TRY(mReadFramebuffer->getImplementationColorReadType(
2267 context, reinterpret_cast<GLenum *>(params)));
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002268 break;
2269 case GL_IMPLEMENTATION_COLOR_READ_FORMAT:
Jamie Madill690c8eb2018-03-12 15:20:03 -04002270 ANGLE_TRY(mReadFramebuffer->getImplementationColorReadFormat(
2271 context, reinterpret_cast<GLenum *>(params)));
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002272 break;
2273 case GL_SAMPLE_BUFFERS:
2274 case GL_SAMPLES:
Shannon Woods53a94a82014-06-24 15:20:36 -04002275 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002276 Framebuffer *framebuffer = mDrawFramebuffer;
Jamie Madill427064d2018-04-13 16:20:34 -04002277 if (framebuffer->isComplete(context))
Shannon Woods53a94a82014-06-24 15:20:36 -04002278 {
Jamie Madill427064d2018-04-13 16:20:34 -04002279 GLint samples = framebuffer->getSamples(context);
Shannon Woods53a94a82014-06-24 15:20:36 -04002280 switch (pname)
2281 {
Jamie Madilla0016b72017-07-14 14:30:46 -04002282 case GL_SAMPLE_BUFFERS:
Jamie Madille98b1b52018-03-08 09:47:23 -05002283 if (samples != 0)
Jamie Madilla0016b72017-07-14 14:30:46 -04002284 {
2285 *params = 1;
2286 }
2287 else
2288 {
2289 *params = 0;
2290 }
2291 break;
2292 case GL_SAMPLES:
Jamie Madille98b1b52018-03-08 09:47:23 -05002293 *params = samples;
Jamie Madilla0016b72017-07-14 14:30:46 -04002294 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002295 }
2296 }
2297 else
2298 {
2299 *params = 0;
2300 }
2301 }
2302 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002303 case GL_VIEWPORT:
2304 params[0] = mViewport.x;
2305 params[1] = mViewport.y;
2306 params[2] = mViewport.width;
2307 params[3] = mViewport.height;
2308 break;
2309 case GL_SCISSOR_BOX:
2310 params[0] = mScissor.x;
2311 params[1] = mScissor.y;
2312 params[2] = mScissor.width;
2313 params[3] = mScissor.height;
2314 break;
2315 case GL_CULL_FACE_MODE:
2316 *params = ToGLenum(mRasterizer.cullMode);
2317 break;
2318 case GL_FRONT_FACE:
2319 *params = mRasterizer.frontFace;
2320 break;
2321 case GL_RED_BITS:
2322 case GL_GREEN_BITS:
2323 case GL_BLUE_BITS:
2324 case GL_ALPHA_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002325 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002326 Framebuffer *framebuffer = getDrawFramebuffer();
2327 const FramebufferAttachment *colorbuffer = framebuffer->getFirstColorbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002328
2329 if (colorbuffer)
2330 {
2331 switch (pname)
2332 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002333 case GL_RED_BITS:
2334 *params = colorbuffer->getRedSize();
2335 break;
2336 case GL_GREEN_BITS:
2337 *params = colorbuffer->getGreenSize();
2338 break;
2339 case GL_BLUE_BITS:
2340 *params = colorbuffer->getBlueSize();
2341 break;
2342 case GL_ALPHA_BITS:
2343 *params = colorbuffer->getAlphaSize();
2344 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002345 }
2346 }
2347 else
2348 {
2349 *params = 0;
2350 }
2351 }
2352 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002353 case GL_DEPTH_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002354 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002355 const Framebuffer *framebuffer = getDrawFramebuffer();
2356 const FramebufferAttachment *depthbuffer = framebuffer->getDepthbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002357
2358 if (depthbuffer)
2359 {
2360 *params = depthbuffer->getDepthSize();
2361 }
2362 else
2363 {
2364 *params = 0;
2365 }
2366 }
2367 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002368 case GL_STENCIL_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002369 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002370 const Framebuffer *framebuffer = getDrawFramebuffer();
2371 const FramebufferAttachment *stencilbuffer = framebuffer->getStencilbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002372
2373 if (stencilbuffer)
2374 {
2375 *params = stencilbuffer->getStencilSize();
2376 }
2377 else
2378 {
2379 *params = 0;
2380 }
2381 }
2382 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002383 case GL_TEXTURE_BINDING_2D:
2384 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2385 *params =
2386 getSamplerTextureId(static_cast<unsigned int>(mActiveSampler), TextureType::_2D);
2387 break;
2388 case GL_TEXTURE_BINDING_RECTANGLE_ANGLE:
2389 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2390 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2391 TextureType::Rectangle);
2392 break;
2393 case GL_TEXTURE_BINDING_CUBE_MAP:
2394 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2395 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2396 TextureType::CubeMap);
2397 break;
2398 case GL_TEXTURE_BINDING_3D:
2399 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2400 *params =
2401 getSamplerTextureId(static_cast<unsigned int>(mActiveSampler), TextureType::_3D);
2402 break;
2403 case GL_TEXTURE_BINDING_2D_ARRAY:
2404 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2405 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2406 TextureType::_2DArray);
2407 break;
2408 case GL_TEXTURE_BINDING_2D_MULTISAMPLE:
2409 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2410 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2411 TextureType::_2DMultisample);
2412 break;
Olli Etuahodff32a02018-08-28 14:35:50 +03002413 case GL_TEXTURE_BINDING_2D_MULTISAMPLE_ARRAY:
2414 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2415 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2416 TextureType::_2DMultisampleArray);
2417 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002418 case GL_TEXTURE_BINDING_EXTERNAL_OES:
2419 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2420 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2421 TextureType::External);
2422 break;
2423 case GL_UNIFORM_BUFFER_BINDING:
2424 *params = mBoundBuffers[BufferBinding::Uniform].id();
2425 break;
2426 case GL_TRANSFORM_FEEDBACK_BINDING:
2427 *params = mTransformFeedback.id();
2428 break;
2429 case GL_TRANSFORM_FEEDBACK_BUFFER_BINDING:
2430 *params = mBoundBuffers[BufferBinding::TransformFeedback].id();
2431 break;
2432 case GL_COPY_READ_BUFFER_BINDING:
2433 *params = mBoundBuffers[BufferBinding::CopyRead].id();
2434 break;
2435 case GL_COPY_WRITE_BUFFER_BINDING:
2436 *params = mBoundBuffers[BufferBinding::CopyWrite].id();
2437 break;
2438 case GL_PIXEL_PACK_BUFFER_BINDING:
2439 *params = mBoundBuffers[BufferBinding::PixelPack].id();
2440 break;
2441 case GL_PIXEL_UNPACK_BUFFER_BINDING:
2442 *params = mBoundBuffers[BufferBinding::PixelUnpack].id();
2443 break;
2444 case GL_READ_BUFFER:
2445 *params = mReadFramebuffer->getReadBufferState();
2446 break;
2447 case GL_SAMPLER_BINDING:
2448 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2449 *params = getSamplerId(static_cast<GLuint>(mActiveSampler));
2450 break;
2451 case GL_DEBUG_LOGGED_MESSAGES:
2452 *params = static_cast<GLint>(mDebug.getMessageCount());
2453 break;
2454 case GL_DEBUG_NEXT_LOGGED_MESSAGE_LENGTH:
2455 *params = static_cast<GLint>(mDebug.getNextMessageLength());
2456 break;
2457 case GL_DEBUG_GROUP_STACK_DEPTH:
2458 *params = static_cast<GLint>(mDebug.getGroupStackDepth());
2459 break;
2460 case GL_MULTISAMPLE_EXT:
2461 *params = static_cast<GLint>(mMultiSampling);
2462 break;
2463 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
2464 *params = static_cast<GLint>(mSampleAlphaToOne);
2465 break;
2466 case GL_COVERAGE_MODULATION_CHROMIUM:
2467 *params = static_cast<GLint>(mCoverageModulation);
2468 break;
2469 case GL_ATOMIC_COUNTER_BUFFER_BINDING:
2470 *params = mBoundBuffers[BufferBinding::AtomicCounter].id();
2471 break;
2472 case GL_SHADER_STORAGE_BUFFER_BINDING:
2473 *params = mBoundBuffers[BufferBinding::ShaderStorage].id();
2474 break;
2475 case GL_DISPATCH_INDIRECT_BUFFER_BINDING:
2476 *params = mBoundBuffers[BufferBinding::DispatchIndirect].id();
2477 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -07002478 case GL_ALPHA_TEST_FUNC:
2479 *params = ToGLenum(mGLES1State.mAlphaTestFunc);
2480 break;
Lingfeng Yang96310cd2018-03-28 11:56:28 -07002481 case GL_CLIENT_ACTIVE_TEXTURE:
2482 *params = mGLES1State.mClientActiveTexture + GL_TEXTURE0;
2483 break;
Lingfeng Yangd2488ab2018-04-04 09:25:48 -07002484 case GL_MATRIX_MODE:
2485 *params = ToGLenum(mGLES1State.mMatrixMode);
2486 break;
Lingfeng Yanga0cfa872018-05-30 21:12:17 -07002487 case GL_SHADE_MODEL:
2488 *params = ToGLenum(mGLES1State.mShadeModel);
2489 break;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -07002490 case GL_MODELVIEW_STACK_DEPTH:
2491 case GL_PROJECTION_STACK_DEPTH:
2492 case GL_TEXTURE_STACK_DEPTH:
2493 *params = mGLES1State.getCurrentMatrixStackDepth(pname);
2494 break;
2495 case GL_LOGIC_OP_MODE:
2496 *params = ToGLenum(mGLES1State.mLogicOp);
2497 break;
2498 case GL_BLEND_SRC:
2499 *params = mBlend.sourceBlendRGB;
2500 break;
2501 case GL_BLEND_DST:
2502 *params = mBlend.destBlendRGB;
2503 break;
2504 case GL_PERSPECTIVE_CORRECTION_HINT:
2505 case GL_POINT_SMOOTH_HINT:
2506 case GL_LINE_SMOOTH_HINT:
2507 case GL_FOG_HINT:
2508 *params = mGLES1State.getHint(pname);
2509 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002510 default:
2511 UNREACHABLE();
2512 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002513 }
Jamie Madille98b1b52018-03-08 09:47:23 -05002514
2515 return NoError();
Shannon Woods53a94a82014-06-24 15:20:36 -04002516}
2517
Lingfeng Yangabb09f12018-04-16 10:43:53 -07002518void State::getPointerv(const Context *context, GLenum pname, void **params) const
Geoff Lang70d0f492015-12-10 17:45:46 -05002519{
2520 switch (pname)
2521 {
2522 case GL_DEBUG_CALLBACK_FUNCTION:
2523 *params = reinterpret_cast<void *>(mDebug.getCallback());
2524 break;
2525 case GL_DEBUG_CALLBACK_USER_PARAM:
2526 *params = const_cast<void *>(mDebug.getUserParam());
2527 break;
Lingfeng Yangabb09f12018-04-16 10:43:53 -07002528 case GL_VERTEX_ARRAY_POINTER:
2529 case GL_NORMAL_ARRAY_POINTER:
2530 case GL_COLOR_ARRAY_POINTER:
2531 case GL_TEXTURE_COORD_ARRAY_POINTER:
2532 case GL_POINT_SIZE_ARRAY_POINTER_OES:
2533 QueryVertexAttribPointerv(getVertexArray()->getVertexAttribute(
2534 context->vertexArrayIndex(ParamToVertexArrayType(pname))),
2535 GL_VERTEX_ATTRIB_ARRAY_POINTER, params);
2536 return;
Geoff Lang70d0f492015-12-10 17:45:46 -05002537 default:
2538 UNREACHABLE();
2539 break;
2540 }
2541}
2542
Martin Radev66fb8202016-07-28 11:45:20 +03002543void State::getIntegeri_v(GLenum target, GLuint index, GLint *data)
Shannon Woods53a94a82014-06-24 15:20:36 -04002544{
2545 switch (target)
2546 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002547 case GL_TRANSFORM_FEEDBACK_BUFFER_BINDING:
2548 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2549 *data = mTransformFeedback->getIndexedBuffer(index).id();
2550 break;
2551 case GL_UNIFORM_BUFFER_BINDING:
2552 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2553 *data = mUniformBuffers[index].id();
2554 break;
2555 case GL_ATOMIC_COUNTER_BUFFER_BINDING:
2556 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2557 *data = mAtomicCounterBuffers[index].id();
2558 break;
2559 case GL_SHADER_STORAGE_BUFFER_BINDING:
2560 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2561 *data = mShaderStorageBuffers[index].id();
2562 break;
2563 case GL_VERTEX_BINDING_BUFFER:
2564 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2565 *data = mVertexArray->getVertexBinding(index).getBuffer().id();
2566 break;
2567 case GL_VERTEX_BINDING_DIVISOR:
2568 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2569 *data = mVertexArray->getVertexBinding(index).getDivisor();
2570 break;
2571 case GL_VERTEX_BINDING_OFFSET:
2572 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2573 *data = static_cast<GLuint>(mVertexArray->getVertexBinding(index).getOffset());
2574 break;
2575 case GL_VERTEX_BINDING_STRIDE:
2576 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2577 *data = mVertexArray->getVertexBinding(index).getStride();
2578 break;
2579 case GL_SAMPLE_MASK_VALUE:
2580 ASSERT(static_cast<size_t>(index) < mSampleMaskValues.size());
2581 *data = mSampleMaskValues[index];
2582 break;
2583 case GL_IMAGE_BINDING_NAME:
2584 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2585 *data = mImageUnits[index].texture.id();
2586 break;
2587 case GL_IMAGE_BINDING_LEVEL:
2588 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2589 *data = mImageUnits[index].level;
2590 break;
2591 case GL_IMAGE_BINDING_LAYER:
2592 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2593 *data = mImageUnits[index].layer;
2594 break;
2595 case GL_IMAGE_BINDING_ACCESS:
2596 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2597 *data = mImageUnits[index].access;
2598 break;
2599 case GL_IMAGE_BINDING_FORMAT:
2600 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2601 *data = mImageUnits[index].format;
2602 break;
2603 default:
2604 UNREACHABLE();
2605 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002606 }
Shannon Woods53a94a82014-06-24 15:20:36 -04002607}
2608
Martin Radev66fb8202016-07-28 11:45:20 +03002609void State::getInteger64i_v(GLenum target, GLuint index, GLint64 *data)
Shannon Woods53a94a82014-06-24 15:20:36 -04002610{
2611 switch (target)
2612 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002613 case GL_TRANSFORM_FEEDBACK_BUFFER_START:
2614 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2615 *data = mTransformFeedback->getIndexedBuffer(index).getOffset();
2616 break;
2617 case GL_TRANSFORM_FEEDBACK_BUFFER_SIZE:
2618 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2619 *data = mTransformFeedback->getIndexedBuffer(index).getSize();
2620 break;
2621 case GL_UNIFORM_BUFFER_START:
2622 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2623 *data = mUniformBuffers[index].getOffset();
2624 break;
2625 case GL_UNIFORM_BUFFER_SIZE:
2626 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2627 *data = mUniformBuffers[index].getSize();
2628 break;
2629 case GL_ATOMIC_COUNTER_BUFFER_START:
2630 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2631 *data = mAtomicCounterBuffers[index].getOffset();
2632 break;
2633 case GL_ATOMIC_COUNTER_BUFFER_SIZE:
2634 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2635 *data = mAtomicCounterBuffers[index].getSize();
2636 break;
2637 case GL_SHADER_STORAGE_BUFFER_START:
2638 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2639 *data = mShaderStorageBuffers[index].getOffset();
2640 break;
2641 case GL_SHADER_STORAGE_BUFFER_SIZE:
2642 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2643 *data = mShaderStorageBuffers[index].getSize();
2644 break;
2645 default:
2646 UNREACHABLE();
2647 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002648 }
Martin Radev66fb8202016-07-28 11:45:20 +03002649}
Shannon Woods53a94a82014-06-24 15:20:36 -04002650
Martin Radev66fb8202016-07-28 11:45:20 +03002651void State::getBooleani_v(GLenum target, GLuint index, GLboolean *data)
2652{
Xinghua Cao9c8e1a32017-12-06 17:59:58 +08002653 switch (target)
2654 {
2655 case GL_IMAGE_BINDING_LAYERED:
2656 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2657 *data = mImageUnits[index].layered;
2658 break;
2659 default:
2660 UNREACHABLE();
2661 break;
2662 }
Shannon Woods53a94a82014-06-24 15:20:36 -04002663}
2664
Jamie Madillbc918e72018-03-08 09:47:21 -05002665Error State::syncDirtyObjects(const Context *context, const DirtyObjects &bitset)
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002666{
Jiajia Qin5ae6ee42018-03-06 17:39:42 +08002667 const DirtyObjects &dirtyObjects = mDirtyObjects & bitset;
2668 for (auto dirtyObject : dirtyObjects)
Jamie Madillc9d442d2016-01-20 11:17:24 -05002669 {
2670 switch (dirtyObject)
2671 {
2672 case DIRTY_OBJECT_READ_FRAMEBUFFER:
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002673 ASSERT(mReadFramebuffer);
Jamie Madill19fa1c62018-03-08 09:47:21 -05002674 ANGLE_TRY(mReadFramebuffer->syncState(context));
Jamie Madillc9d442d2016-01-20 11:17:24 -05002675 break;
2676 case DIRTY_OBJECT_DRAW_FRAMEBUFFER:
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002677 ASSERT(mDrawFramebuffer);
Jamie Madill19fa1c62018-03-08 09:47:21 -05002678 ANGLE_TRY(mDrawFramebuffer->syncState(context));
Jamie Madillc9d442d2016-01-20 11:17:24 -05002679 break;
2680 case DIRTY_OBJECT_VERTEX_ARRAY:
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002681 ASSERT(mVertexArray);
Frank Henigman0af5b862018-03-27 20:19:33 -04002682 ANGLE_TRY(mVertexArray->syncState(context));
Jamie Madillc9d442d2016-01-20 11:17:24 -05002683 break;
Jamie Madille25b8002018-09-20 13:39:49 -04002684 case DIRTY_OBJECT_SAMPLERS:
2685 syncSamplers(context);
2686 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002687 case DIRTY_OBJECT_PROGRAM_TEXTURES:
Luc Ferron4bba74f2018-04-19 14:40:45 -04002688 ANGLE_TRY(syncProgramTextures(context));
Jamie Madill81c2e252017-09-09 23:32:46 -04002689 break;
Jamie Madill70aeda42018-08-20 12:17:40 -04002690 case DIRTY_OBJECT_PROGRAM:
2691 ANGLE_TRY(mProgram->syncState(context));
2692 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002693
Jamie Madillc9d442d2016-01-20 11:17:24 -05002694 default:
2695 UNREACHABLE();
2696 break;
2697 }
2698 }
2699
Jiajia Qin5ae6ee42018-03-06 17:39:42 +08002700 mDirtyObjects &= ~dirtyObjects;
Jamie Madillbc918e72018-03-08 09:47:21 -05002701 return NoError();
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002702}
2703
Jamie Madille25b8002018-09-20 13:39:49 -04002704void State::syncSamplers(const Context *context)
2705{
2706 if (mDirtySamplers.none())
2707 return;
2708
2709 // This could be optimized by tracking which samplers are dirty.
2710 for (size_t samplerIndex : mDirtySamplers)
2711 {
2712 BindingPointer<Sampler> &sampler = mSamplers[samplerIndex];
2713 if (sampler.get())
2714 {
2715 sampler->syncState(context);
2716 }
2717 }
2718
2719 mDirtySamplers.reset();
2720}
2721
Luc Ferron4bba74f2018-04-19 14:40:45 -04002722Error State::syncProgramTextures(const Context *context)
Jamie Madill81c2e252017-09-09 23:32:46 -04002723{
Jamie Madill81c2e252017-09-09 23:32:46 -04002724 // TODO(jmadill): Fine-grained updates.
2725 if (!mProgram)
2726 {
Luc Ferron4bba74f2018-04-19 14:40:45 -04002727 return NoError();
Jamie Madill81c2e252017-09-09 23:32:46 -04002728 }
2729
2730 ASSERT(mDirtyObjects[DIRTY_OBJECT_PROGRAM_TEXTURES]);
2731 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
2732
Jamie Madill0f80ed82017-09-19 00:24:56 -04002733 ActiveTextureMask newActiveTextures;
2734
Geoff Lange51ba632017-11-21 11:45:25 -05002735 // Initialize to the 'Initialized' state and set to 'MayNeedInit' if any texture is not
2736 // initialized.
2737 mCachedTexturesInitState = InitState::Initialized;
Qin Jiajia47f6dd02018-08-10 13:36:32 +08002738 mCachedImageTexturesInitState = InitState::Initialized;
Geoff Lange51ba632017-11-21 11:45:25 -05002739
Jamie Madill7e4eff12018-08-08 15:49:26 -04002740 const ActiveTextureMask &activeTextures = mProgram->getActiveSamplersMask();
2741 const ActiveTextureArray<TextureType> &textureTypes = mProgram->getActiveSamplerTypes();
2742
2743 for (size_t textureUnitIndex : activeTextures)
Jamie Madill81c2e252017-09-09 23:32:46 -04002744 {
Jamie Madill7e4eff12018-08-08 15:49:26 -04002745 TextureType textureType = textureTypes[textureUnitIndex];
Jamie Madill81c2e252017-09-09 23:32:46 -04002746
jchen1090f466a2018-08-13 15:05:25 +08002747 Texture *texture =
2748 getSamplerTexture(static_cast<unsigned int>(textureUnitIndex), textureType);
2749 Sampler *sampler = getSampler(static_cast<GLuint>(textureUnitIndex));
Jamie Madill4787d702018-08-08 15:49:26 -04002750 ASSERT(static_cast<size_t>(textureUnitIndex) < mActiveTexturesCache.size());
Jamie Madill7e4eff12018-08-08 15:49:26 -04002751 ASSERT(static_cast<size_t>(textureUnitIndex) < newActiveTextures.size());
2752
2753 ASSERT(texture);
2754
2755 // Mark the texture binding bit as dirty if the texture completeness changes.
2756 // TODO(jmadill): Use specific dirty bit for completeness change.
2757 if (texture->isSamplerComplete(context, sampler) &&
Jamie Madille25b8002018-09-20 13:39:49 -04002758 (mProgram->hasLinkedShaderStage(ShaderType::Compute) ||
2759 !mDrawFramebuffer->hasTextureAttachment(texture)))
Jamie Madill81c2e252017-09-09 23:32:46 -04002760 {
Jamie Madill7e4eff12018-08-08 15:49:26 -04002761 ANGLE_TRY(texture->syncState(context));
Jamie Madill4787d702018-08-08 15:49:26 -04002762 mActiveTexturesCache[textureUnitIndex] = texture;
Jamie Madill7e4eff12018-08-08 15:49:26 -04002763 }
2764 else
2765 {
Jamie Madill4787d702018-08-08 15:49:26 -04002766 mActiveTexturesCache[textureUnitIndex] = nullptr;
Jamie Madill7e4eff12018-08-08 15:49:26 -04002767 }
Jamie Madill81c2e252017-09-09 23:32:46 -04002768
Jamie Madill7e4eff12018-08-08 15:49:26 -04002769 // Bind the texture unconditionally, to recieve completeness change notifications.
2770 mCompleteTextureBindings[textureUnitIndex].bind(texture->getSubject());
2771 newActiveTextures.set(textureUnitIndex);
Jamie Madill81c2e252017-09-09 23:32:46 -04002772
Jamie Madill7e4eff12018-08-08 15:49:26 -04002773 if (texture->initState() == InitState::MayNeedInit)
2774 {
2775 mCachedTexturesInitState = InitState::MayNeedInit;
Jamie Madill81c2e252017-09-09 23:32:46 -04002776 }
2777 }
Jamie Madill0f80ed82017-09-19 00:24:56 -04002778
2779 // Unset now missing textures.
Jamie Madill7e4eff12018-08-08 15:49:26 -04002780 ActiveTextureMask negativeMask = activeTextures & ~newActiveTextures;
Jamie Madill0f80ed82017-09-19 00:24:56 -04002781 if (negativeMask.any())
2782 {
2783 for (auto textureIndex : negativeMask)
2784 {
2785 mCompleteTextureBindings[textureIndex].reset();
Jamie Madill4787d702018-08-08 15:49:26 -04002786 mActiveTexturesCache[textureIndex] = nullptr;
Jamie Madill0f80ed82017-09-19 00:24:56 -04002787 }
2788 }
Luc Ferron4bba74f2018-04-19 14:40:45 -04002789
Qin Jiajia47f6dd02018-08-10 13:36:32 +08002790 for (size_t imageUnitIndex : mProgram->getActiveImagesMask())
2791 {
2792 Texture *texture = mImageUnits[imageUnitIndex].texture.get();
2793 if (!texture)
2794 {
2795 continue;
2796 }
2797 if (!mDrawFramebuffer->hasTextureAttachment(texture))
2798 {
2799 ANGLE_TRY(texture->syncState(context));
2800 }
2801 if (texture->initState() == InitState::MayNeedInit)
2802 {
2803 mCachedImageTexturesInitState = InitState::MayNeedInit;
2804 }
2805 }
2806
Luc Ferron4bba74f2018-04-19 14:40:45 -04002807 return NoError();
Jamie Madill81c2e252017-09-09 23:32:46 -04002808}
2809
Jamie Madillbc918e72018-03-08 09:47:21 -05002810Error State::syncDirtyObject(const Context *context, GLenum target)
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002811{
2812 DirtyObjects localSet;
2813
2814 switch (target)
2815 {
2816 case GL_READ_FRAMEBUFFER:
2817 localSet.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2818 break;
2819 case GL_DRAW_FRAMEBUFFER:
2820 localSet.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2821 break;
2822 case GL_FRAMEBUFFER:
2823 localSet.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2824 localSet.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2825 break;
2826 case GL_VERTEX_ARRAY:
2827 localSet.set(DIRTY_OBJECT_VERTEX_ARRAY);
2828 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002829 case GL_TEXTURE:
Jamie Madille25b8002018-09-20 13:39:49 -04002830 localSet.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
2831 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002832 case GL_SAMPLER:
Jamie Madill70aeda42018-08-20 12:17:40 -04002833 localSet.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Jamie Madille25b8002018-09-20 13:39:49 -04002834 localSet.set(DIRTY_OBJECT_SAMPLERS);
Jamie Madill70aeda42018-08-20 12:17:40 -04002835 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002836 case GL_PROGRAM:
2837 localSet.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Jamie Madill70aeda42018-08-20 12:17:40 -04002838 localSet.set(DIRTY_OBJECT_PROGRAM);
Jamie Madill81c2e252017-09-09 23:32:46 -04002839 break;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002840 }
2841
Jamie Madillbc918e72018-03-08 09:47:21 -05002842 return syncDirtyObjects(context, localSet);
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002843}
2844
2845void State::setObjectDirty(GLenum target)
2846{
2847 switch (target)
2848 {
2849 case GL_READ_FRAMEBUFFER:
2850 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2851 break;
2852 case GL_DRAW_FRAMEBUFFER:
2853 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2854 break;
2855 case GL_FRAMEBUFFER:
2856 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2857 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2858 break;
2859 case GL_VERTEX_ARRAY:
2860 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
2861 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002862 case GL_TEXTURE:
Jamie Madill70aeda42018-08-20 12:17:40 -04002863 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
2864 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
2865 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002866 case GL_PROGRAM:
2867 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Jamie Madill70aeda42018-08-20 12:17:40 -04002868 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM);
Jamie Madill81c2e252017-09-09 23:32:46 -04002869 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
2870 break;
Jamie Madilla779b612017-07-24 11:46:05 -04002871 }
2872}
2873
2874void State::onProgramExecutableChange(Program *program)
2875{
2876 // OpenGL Spec:
2877 // "If LinkProgram or ProgramBinary successfully re-links a program object
2878 // that was already in use as a result of a previous call to UseProgram, then the
2879 // generated executable code will be installed as part of the current rendering state."
2880 if (program->isLinked() && mProgram == program)
2881 {
2882 mDirtyBits.set(DIRTY_BIT_PROGRAM_EXECUTABLE);
Jamie Madill81c2e252017-09-09 23:32:46 -04002883 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Jamie Madill70aeda42018-08-20 12:17:40 -04002884 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM);
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002885 }
Shannon Woods53a94a82014-06-24 15:20:36 -04002886}
Jamie Madillc9d442d2016-01-20 11:17:24 -05002887
Jamie Madille25b8002018-09-20 13:39:49 -04002888void State::setSamplerDirty(size_t samplerIndex)
2889{
2890 mDirtyObjects.set(DIRTY_OBJECT_SAMPLERS);
2891 mDirtySamplers.set(samplerIndex);
2892}
2893
Xinghua Cao65ec0b22017-03-28 16:10:52 +08002894void State::setImageUnit(const Context *context,
Will Harris63aa0e52018-09-05 16:15:46 -07002895 size_t unit,
Xinghua Cao65ec0b22017-03-28 16:10:52 +08002896 Texture *texture,
2897 GLint level,
2898 GLboolean layered,
2899 GLint layer,
2900 GLenum access,
2901 GLenum format)
2902{
2903 mImageUnits[unit].texture.set(context, texture);
2904 mImageUnits[unit].level = level;
2905 mImageUnits[unit].layered = layered;
2906 mImageUnits[unit].layer = layer;
2907 mImageUnits[unit].access = access;
2908 mImageUnits[unit].format = format;
jchen1099118c12018-09-10 16:28:51 +08002909 mDirtyBits.set(DIRTY_BIT_IMAGE_BINDINGS);
Xinghua Cao65ec0b22017-03-28 16:10:52 +08002910}
2911
Will Harris63aa0e52018-09-05 16:15:46 -07002912const ImageUnit &State::getImageUnit(size_t unit) const
Xinghua Cao65ec0b22017-03-28 16:10:52 +08002913{
2914 return mImageUnits[unit];
2915}
2916
Jamie Madill81c2e252017-09-09 23:32:46 -04002917// Handle a dirty texture event.
Jamie Madill6c43a012018-08-08 15:49:27 -04002918void State::onActiveTextureStateChange(size_t textureIndex)
Jamie Madill81c2e252017-09-09 23:32:46 -04002919{
2920 // Conservatively assume all textures are dirty.
2921 // TODO(jmadill): More fine-grained update.
2922 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Geoff Lange51ba632017-11-21 11:45:25 -05002923
Jamie Madill6c43a012018-08-08 15:49:27 -04002924 if (!mActiveTexturesCache[textureIndex] ||
2925 mActiveTexturesCache[textureIndex]->initState() == InitState::MayNeedInit)
Geoff Lange51ba632017-11-21 11:45:25 -05002926 {
2927 mCachedTexturesInitState = InitState::MayNeedInit;
2928 }
Jamie Madill81c2e252017-09-09 23:32:46 -04002929}
2930
Jamie Madill6d32cef2018-08-14 02:34:28 -04002931void State::onUniformBufferStateChange(size_t uniformBufferIndex)
2932{
2933 // This could be represented by a different dirty bit. Using the same one keeps it simple.
2934 mDirtyBits.set(DIRTY_BIT_UNIFORM_BUFFER_BINDINGS);
2935}
2936
Jamie Madill05b35b22017-10-03 09:01:44 -04002937Error State::clearUnclearedActiveTextures(const Context *context)
2938{
Jamie Madilla59fc192017-11-02 12:57:58 -04002939 ASSERT(mRobustResourceInit);
Geoff Lang9bf86f02018-07-26 11:46:34 -04002940 ASSERT(!mDirtyObjects[DIRTY_OBJECT_PROGRAM_TEXTURES]);
Geoff Langd4fff502017-09-22 11:28:28 -04002941
Jamie Madill7e4eff12018-08-08 15:49:26 -04002942 if (!mProgram)
2943 return NoError();
2944
Qin Jiajia47f6dd02018-08-10 13:36:32 +08002945 if (mCachedTexturesInitState != InitState::Initialized)
Jamie Madill05b35b22017-10-03 09:01:44 -04002946 {
Qin Jiajia47f6dd02018-08-10 13:36:32 +08002947 for (size_t textureUnitIndex : mProgram->getActiveSamplersMask())
Jamie Madill05b35b22017-10-03 09:01:44 -04002948 {
Qin Jiajia47f6dd02018-08-10 13:36:32 +08002949 Texture *texture = mActiveTexturesCache[textureUnitIndex];
2950 if (texture)
2951 {
2952 ANGLE_TRY(texture->ensureInitialized(context));
2953 }
Jamie Madill05b35b22017-10-03 09:01:44 -04002954 }
Qin Jiajia47f6dd02018-08-10 13:36:32 +08002955 mCachedTexturesInitState = InitState::Initialized;
Jamie Madill05b35b22017-10-03 09:01:44 -04002956 }
Qin Jiajia47f6dd02018-08-10 13:36:32 +08002957 if (mCachedImageTexturesInitState != InitState::Initialized)
2958 {
2959 for (size_t imageUnitIndex : mProgram->getActiveImagesMask())
2960 {
2961 Texture *texture = mImageUnits[imageUnitIndex].texture.get();
2962 if (texture)
2963 {
2964 ANGLE_TRY(texture->ensureInitialized(context));
2965 }
2966 }
2967 mCachedImageTexturesInitState = InitState::Initialized;
2968 }
Jamie Madill05b35b22017-10-03 09:01:44 -04002969 return NoError();
2970}
2971
Jamie Madillc67323a2017-11-02 23:11:41 -04002972AttributesMask State::getAndResetDirtyCurrentValues() const
2973{
2974 AttributesMask retVal = mDirtyCurrentValues;
2975 mDirtyCurrentValues.reset();
2976 return retVal;
2977}
2978
James Darpiniane8a93c62018-01-04 18:02:24 -08002979bool State::isCurrentTransformFeedback(const TransformFeedback *tf) const
2980{
2981 return tf == mTransformFeedback.get();
2982}
Jamie Madillc9d442d2016-01-20 11:17:24 -05002983} // namespace gl