blob: 40f437314f95f25fc8f917b35a93bc0240c40dc7 [file] [log] [blame]
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001//
Geoff Langeeba6e12014-02-03 13:12:30 -05002// Copyright (c) 2002-2014 The ANGLE Project Authors. All rights reserved.
apatrick@chromium.org144f2802012-07-12 01:42:34 +00003// Use of this source code is governed by a BSD-style license that can be
4// found in the LICENSE file.
5//
6
7// Context.cpp: Implements the gl::Context class, managing all GL state and performing
8// rendering operations. It is the GLES2 specific implementation of EGLContext.
9
Geoff Lang2b5420c2014-11-19 14:20:15 -050010#include "libANGLE/Context.h"
apatrick@chromium.org144f2802012-07-12 01:42:34 +000011
Jamie Madillb9293972015-02-19 11:07:54 -050012#include <iterator>
13#include <sstream>
14
Geoff Lang0b7eef72014-06-12 14:10:47 -040015#include "common/platform.h"
Jamie Madillb9293972015-02-19 11:07:54 -050016#include "common/utilities.h"
Geoff Lang2b5420c2014-11-19 14:20:15 -050017#include "libANGLE/Buffer.h"
Jamie Madillb9293972015-02-19 11:07:54 -050018#include "libANGLE/Compiler.h"
Jamie Madill9dd0cf02014-11-24 11:38:51 -050019#include "libANGLE/Display.h"
Geoff Lang2b5420c2014-11-19 14:20:15 -050020#include "libANGLE/Fence.h"
21#include "libANGLE/Framebuffer.h"
22#include "libANGLE/FramebufferAttachment.h"
Geoff Lang2b5420c2014-11-19 14:20:15 -050023#include "libANGLE/Program.h"
Geoff Lang2b5420c2014-11-19 14:20:15 -050024#include "libANGLE/Query.h"
Jamie Madillb9293972015-02-19 11:07:54 -050025#include "libANGLE/Renderbuffer.h"
Geoff Lang2b5420c2014-11-19 14:20:15 -050026#include "libANGLE/ResourceManager.h"
27#include "libANGLE/Sampler.h"
Jamie Madill9dd0cf02014-11-24 11:38:51 -050028#include "libANGLE/Surface.h"
Geoff Lang2b5420c2014-11-19 14:20:15 -050029#include "libANGLE/Texture.h"
30#include "libANGLE/TransformFeedback.h"
31#include "libANGLE/VertexArray.h"
32#include "libANGLE/formatutils.h"
33#include "libANGLE/validationES.h"
34#include "libANGLE/renderer/Renderer.h"
shannon.woods@transgaming.com486d9e92013-02-28 23:15:41 +000035
apatrick@chromium.org144f2802012-07-12 01:42:34 +000036namespace gl
37{
daniel@transgaming.comca1ac1f2013-01-11 04:13:05 +000038
Corentin Wallez51706ea2015-08-07 14:39:22 -040039Context::Context(const egl::Config *config,
40 int clientVersion,
41 const Context *shareContext,
42 rx::Renderer *renderer,
43 bool notifyResets,
44 bool robustAccess)
Jamie Madillc185cb82015-04-28 12:39:08 -040045 : mRenderer(renderer),
Corentin Walleze3b10e82015-05-20 11:06:25 -040046 mConfig(config),
Corentin Wallez51706ea2015-08-07 14:39:22 -040047 mCurrentSurface(nullptr),
Jamie Madillc185cb82015-04-28 12:39:08 -040048 mData(clientVersion, mState, mCaps, mTextureCaps, mExtensions, nullptr)
apatrick@chromium.org144f2802012-07-12 01:42:34 +000049{
50 ASSERT(robustAccess == false); // Unimplemented
51
Geoff Lang493daf52014-07-03 13:38:44 -040052 initCaps(clientVersion);
Geoff Lang76b10c92014-09-05 16:28:14 -040053 mState.initialize(mCaps, clientVersion);
Geoff Langc0b9ef42014-07-02 10:02:37 -040054
shannon.woods%transgaming.com@gtempaccount.comdaea4b42013-04-13 03:28:54 +000055 mClientVersion = clientVersion;
56
Régis Fénéon83107972015-02-05 12:57:44 +010057 mClientType = EGL_OPENGL_ES_API;
Régis Fénéon83107972015-02-05 12:57:44 +010058
Shannon Woods53a94a82014-06-24 15:20:36 -040059 mFenceNVHandleAllocator.setBaseHandle(0);
Geoff Lang7dca1862013-07-30 16:30:46 -040060
apatrick@chromium.org144f2802012-07-12 01:42:34 +000061 if (shareContext != NULL)
62 {
63 mResourceManager = shareContext->mResourceManager;
64 mResourceManager->addRef();
65 }
66 else
67 {
daniel@transgaming.com370482e2012-11-28 19:32:13 +000068 mResourceManager = new ResourceManager(mRenderer);
apatrick@chromium.org144f2802012-07-12 01:42:34 +000069 }
70
Jamie Madillc185cb82015-04-28 12:39:08 -040071 mData.resourceManager = mResourceManager;
72
apatrick@chromium.org144f2802012-07-12 01:42:34 +000073 // [OpenGL ES 2.0.24] section 3.7 page 83:
74 // In the initial state, TEXTURE_2D and TEXTURE_CUBE_MAP have twodimensional
75 // and cube map texture state vectors respectively associated with them.
76 // In order that access to these initial textures not be lost, they are treated as texture
77 // objects all of whose names are 0.
78
Geoff Lang691e58c2014-12-19 17:03:25 -050079 Texture *zeroTexture2D = new Texture(mRenderer->createTexture(GL_TEXTURE_2D), 0, GL_TEXTURE_2D);
Jamie Madilldedd7b92014-11-05 16:30:36 -050080 mZeroTextures[GL_TEXTURE_2D].set(zeroTexture2D);
Jamie Madilldedd7b92014-11-05 16:30:36 -050081
Geoff Lang691e58c2014-12-19 17:03:25 -050082 Texture *zeroTextureCube = new Texture(mRenderer->createTexture(GL_TEXTURE_CUBE_MAP), 0, GL_TEXTURE_CUBE_MAP);
Jamie Madilldedd7b92014-11-05 16:30:36 -050083 mZeroTextures[GL_TEXTURE_CUBE_MAP].set(zeroTextureCube);
Geoff Lang76b10c92014-09-05 16:28:14 -040084
85 if (mClientVersion >= 3)
86 {
87 // TODO: These could also be enabled via extension
Geoff Lang691e58c2014-12-19 17:03:25 -050088 Texture *zeroTexture3D = new Texture(mRenderer->createTexture(GL_TEXTURE_3D), 0, GL_TEXTURE_3D);
Jamie Madilldedd7b92014-11-05 16:30:36 -050089 mZeroTextures[GL_TEXTURE_3D].set(zeroTexture3D);
Geoff Lang76b10c92014-09-05 16:28:14 -040090
Geoff Lang691e58c2014-12-19 17:03:25 -050091 Texture *zeroTexture2DArray = new Texture(mRenderer->createTexture(GL_TEXTURE_2D_ARRAY), 0, GL_TEXTURE_2D_ARRAY);
Jamie Madilldedd7b92014-11-05 16:30:36 -050092 mZeroTextures[GL_TEXTURE_2D_ARRAY].set(zeroTexture2DArray);
Geoff Lang76b10c92014-09-05 16:28:14 -040093 }
apatrick@chromium.org144f2802012-07-12 01:42:34 +000094
Jamie Madille6382c32014-11-07 15:05:26 -050095 mState.initializeZeroTextures(mZeroTextures);
96
Jamie Madill57a89722013-07-02 11:57:03 -040097 bindVertexArray(0);
apatrick@chromium.org144f2802012-07-12 01:42:34 +000098 bindArrayBuffer(0);
99 bindElementArrayBuffer(0);
Geoff Lang76b10c92014-09-05 16:28:14 -0400100
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000101 bindRenderbuffer(0);
102
shannon.woods%transgaming.com@gtempaccount.com667a29c2013-04-13 03:39:04 +0000103 bindGenericUniformBuffer(0);
Shannon Woodsf3acaf92014-09-23 18:07:11 -0400104 for (unsigned int i = 0; i < mCaps.maxCombinedUniformBlocks; i++)
shannon.woods%transgaming.com@gtempaccount.com667a29c2013-04-13 03:39:04 +0000105 {
106 bindIndexedUniformBuffer(0, i, 0, -1);
107 }
108
shannon.woods%transgaming.com@gtempaccount.com51171882013-04-13 03:39:10 +0000109 bindCopyReadBuffer(0);
110 bindCopyWriteBuffer(0);
shannon.woods%transgaming.com@gtempaccount.comc926e5f2013-04-13 03:39:18 +0000111 bindPixelPackBuffer(0);
112 bindPixelUnpackBuffer(0);
shannon.woods%transgaming.com@gtempaccount.com51171882013-04-13 03:39:10 +0000113
Geoff Langc8058452014-02-03 12:04:11 -0500114 // [OpenGL ES 3.0.2] section 2.14.1 pg 85:
115 // In the initial state, a default transform feedback object is bound and treated as
116 // a transform feedback object with a name of zero. That object is bound any time
117 // BindTransformFeedback is called with id of zero
Geoff Lang045536b2015-03-27 15:17:18 -0400118 mTransformFeedbackZero.set(new TransformFeedback(mRenderer->createTransformFeedback(), 0, mCaps));
Geoff Langc8058452014-02-03 12:04:11 -0500119 bindTransformFeedback(0);
120
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000121 mHasBeenCurrent = false;
122 mContextLost = false;
123 mResetStatus = GL_NO_ERROR;
124 mResetStrategy = (notifyResets ? GL_LOSE_CONTEXT_ON_RESET_EXT : GL_NO_RESET_NOTIFICATION_EXT);
125 mRobustAccess = robustAccess;
Geoff Lang492a7e42014-11-05 13:27:06 -0500126
127 mCompiler = new Compiler(mRenderer->createCompiler(getData()));
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000128}
129
130Context::~Context()
131{
Geoff Lang7dd2e102014-11-10 15:19:26 -0500132 mState.reset();
Geoff Lang21329412014-12-02 20:50:30 +0000133
Corentin Wallez37c39792015-08-20 14:19:46 -0400134 for (auto framebuffer : mFramebufferMap)
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000135 {
Corentin Wallez37c39792015-08-20 14:19:46 -0400136 // Default framebuffer are owned by their respective Surface
137 if (framebuffer.second->id() != 0)
138 {
139 SafeDelete(framebuffer.second);
140 }
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000141 }
142
Corentin Wallez80b24112015-08-25 16:41:57 -0400143 for (auto fence : mFenceNVMap)
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000144 {
Corentin Wallez80b24112015-08-25 16:41:57 -0400145 SafeDelete(fence.second);
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000146 }
147
Corentin Wallez80b24112015-08-25 16:41:57 -0400148 for (auto query : mQueryMap)
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000149 {
Corentin Wallez80b24112015-08-25 16:41:57 -0400150 query.second->release();
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000151 }
152
Corentin Wallez80b24112015-08-25 16:41:57 -0400153 for (auto vertexArray : mVertexArrayMap)
Jamie Madill57a89722013-07-02 11:57:03 -0400154 {
Corentin Wallez80b24112015-08-25 16:41:57 -0400155 SafeDelete(vertexArray.second);
Jamie Madill57a89722013-07-02 11:57:03 -0400156 }
157
Geoff Langc8058452014-02-03 12:04:11 -0500158 mTransformFeedbackZero.set(NULL);
Corentin Wallez80b24112015-08-25 16:41:57 -0400159 for (auto transformFeedback : mTransformFeedbackMap)
Geoff Langc8058452014-02-03 12:04:11 -0500160 {
Corentin Wallez80b24112015-08-25 16:41:57 -0400161 SafeDelete(transformFeedback.second);
Geoff Langc8058452014-02-03 12:04:11 -0500162 }
163
Jamie Madilldedd7b92014-11-05 16:30:36 -0500164 for (auto &zeroTexture : mZeroTextures)
Geoff Lang76b10c92014-09-05 16:28:14 -0400165 {
Jamie Madilldedd7b92014-11-05 16:30:36 -0500166 zeroTexture.second.set(NULL);
Geoff Lang76b10c92014-09-05 16:28:14 -0400167 }
168 mZeroTextures.clear();
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000169
Corentin Wallez51706ea2015-08-07 14:39:22 -0400170 if (mCurrentSurface != nullptr)
171 {
172 releaseSurface();
173 }
174
Jamie Madill1e9ae072014-11-06 15:27:21 -0500175 if (mResourceManager)
176 {
177 mResourceManager->release();
178 }
Geoff Lang492a7e42014-11-05 13:27:06 -0500179
180 SafeDelete(mCompiler);
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000181}
182
daniel@transgaming.comad629872012-11-28 19:32:06 +0000183void Context::makeCurrent(egl::Surface *surface)
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000184{
Jamie Madill77a72f62015-04-14 11:18:32 -0400185 ASSERT(surface != nullptr);
186
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000187 if (!mHasBeenCurrent)
188 {
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000189 initRendererString();
Geoff Langcec35902014-04-16 10:52:36 -0400190 initExtensionStrings();
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000191
Shannon Woods53a94a82014-06-24 15:20:36 -0400192 mState.setViewportParams(0, 0, surface->getWidth(), surface->getHeight());
193 mState.setScissorParams(0, 0, surface->getWidth(), surface->getHeight());
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000194
195 mHasBeenCurrent = true;
196 }
197
Jamie Madill1b94d432015-08-07 13:23:23 -0400198 // TODO(jmadill): Rework this when we support ContextImpl
199 mState.setAllDirtyBits();
200
Corentin Wallez51706ea2015-08-07 14:39:22 -0400201 if (mCurrentSurface)
202 {
203 releaseSurface();
204 }
Jamie Madill18fdcbc2015-08-19 18:12:44 +0000205 surface->setIsCurrent(true);
Corentin Wallez37c39792015-08-20 14:19:46 -0400206 mCurrentSurface = surface;
Jamie Madill18fdcbc2015-08-19 18:12:44 +0000207
Corentin Wallez37c39792015-08-20 14:19:46 -0400208 // Update default framebuffer, the binding of the previous default
209 // framebuffer (or lack of) will have a nullptr.
Jamie Madillc1c1cdc2015-04-30 09:42:26 -0400210 {
Corentin Wallez37c39792015-08-20 14:19:46 -0400211 Framebuffer *newDefault = surface->getDefaultFramebuffer();
212 if (mState.getReadFramebuffer() == nullptr)
213 {
214 mState.setReadFramebufferBinding(newDefault);
215 }
216 if (mState.getDrawFramebuffer() == nullptr)
217 {
218 mState.setDrawFramebufferBinding(newDefault);
219 }
220 mFramebufferMap[0] = newDefault;
Jamie Madillc1c1cdc2015-04-30 09:42:26 -0400221 }
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000222}
223
Jamie Madill77a72f62015-04-14 11:18:32 -0400224void Context::releaseSurface()
225{
Corentin Wallez37c39792015-08-20 14:19:46 -0400226 ASSERT(mCurrentSurface != nullptr);
227
228 // Remove the default framebuffer
Corentin Wallez51706ea2015-08-07 14:39:22 -0400229 {
Corentin Wallez37c39792015-08-20 14:19:46 -0400230 Framebuffer *currentDefault = mCurrentSurface->getDefaultFramebuffer();
231 if (mState.getReadFramebuffer() == currentDefault)
232 {
233 mState.setReadFramebufferBinding(nullptr);
234 }
235 if (mState.getDrawFramebuffer() == currentDefault)
236 {
237 mState.setDrawFramebufferBinding(nullptr);
238 }
239 mFramebufferMap.erase(0);
Corentin Wallez51706ea2015-08-07 14:39:22 -0400240 }
241
Corentin Wallez51706ea2015-08-07 14:39:22 -0400242 mCurrentSurface->setIsCurrent(false);
243 mCurrentSurface = nullptr;
Jamie Madill77a72f62015-04-14 11:18:32 -0400244}
245
daniel@transgaming.comf688c0d2012-10-31 17:52:57 +0000246// NOTE: this function should not assume that this context is current!
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000247void Context::markContextLost()
248{
249 if (mResetStrategy == GL_LOSE_CONTEXT_ON_RESET_EXT)
250 mResetStatus = GL_UNKNOWN_CONTEXT_RESET_EXT;
251 mContextLost = true;
252}
253
254bool Context::isContextLost()
255{
256 return mContextLost;
257}
258
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000259GLuint Context::createBuffer()
260{
261 return mResourceManager->createBuffer();
262}
263
264GLuint Context::createProgram()
265{
266 return mResourceManager->createProgram();
267}
268
269GLuint Context::createShader(GLenum type)
270{
Jamie Madill245d3602014-11-13 10:03:30 -0500271 return mResourceManager->createShader(getData(), type);
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000272}
273
274GLuint Context::createTexture()
275{
276 return mResourceManager->createTexture();
277}
278
279GLuint Context::createRenderbuffer()
280{
281 return mResourceManager->createRenderbuffer();
282}
283
Geoff Lang882033e2014-09-30 11:26:07 -0400284GLsync Context::createFenceSync()
Jamie Madillcd055f82013-07-26 11:55:15 -0400285{
286 GLuint handle = mResourceManager->createFenceSync();
287
Cooper Partind8e62a32015-01-29 15:21:25 -0800288 return reinterpret_cast<GLsync>(static_cast<uintptr_t>(handle));
Jamie Madillcd055f82013-07-26 11:55:15 -0400289}
290
Jamie Madill57a89722013-07-02 11:57:03 -0400291GLuint Context::createVertexArray()
292{
293 GLuint handle = mVertexArrayHandleAllocator.allocate();
294
Jamie Madilld1028542013-07-02 11:57:04 -0400295 // Although the spec states VAO state is not initialized until the object is bound,
296 // we create it immediately. The resulting behaviour is transparent to the application,
297 // since it's not currently possible to access the state until the object is bound.
Jamie Madill8e344942015-07-09 14:22:07 -0400298 VertexArray *vertexArray = new VertexArray(mRenderer, handle, MAX_VERTEX_ATTRIBS);
Shannon Woodsaa2ab7d2014-06-24 17:51:51 -0400299 mVertexArrayMap[handle] = vertexArray;
Jamie Madill57a89722013-07-02 11:57:03 -0400300 return handle;
301}
302
Jamie Madilldc356042013-07-19 16:36:57 -0400303GLuint Context::createSampler()
304{
305 return mResourceManager->createSampler();
306}
307
Geoff Langc8058452014-02-03 12:04:11 -0500308GLuint Context::createTransformFeedback()
309{
310 GLuint handle = mTransformFeedbackAllocator.allocate();
Geoff Lang045536b2015-03-27 15:17:18 -0400311 TransformFeedback *transformFeedback = new TransformFeedback(mRenderer->createTransformFeedback(), handle, mCaps);
Geoff Langc8058452014-02-03 12:04:11 -0500312 transformFeedback->addRef();
313 mTransformFeedbackMap[handle] = transformFeedback;
314 return handle;
315}
316
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000317// Returns an unused framebuffer name
318GLuint Context::createFramebuffer()
319{
320 GLuint handle = mFramebufferHandleAllocator.allocate();
321
322 mFramebufferMap[handle] = NULL;
323
324 return handle;
325}
326
Jamie Madill33dc8432013-07-26 11:55:05 -0400327GLuint Context::createFenceNV()
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000328{
Jamie Madill33dc8432013-07-26 11:55:05 -0400329 GLuint handle = mFenceNVHandleAllocator.allocate();
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000330
Kenneth Russellcaa549c2014-10-10 17:52:59 -0700331 mFenceNVMap[handle] = new FenceNV(mRenderer->createFenceNV());
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000332
333 return handle;
334}
335
336// Returns an unused query name
337GLuint Context::createQuery()
338{
339 GLuint handle = mQueryHandleAllocator.allocate();
340
341 mQueryMap[handle] = NULL;
342
343 return handle;
344}
345
346void Context::deleteBuffer(GLuint buffer)
347{
348 if (mResourceManager->getBuffer(buffer))
349 {
350 detachBuffer(buffer);
351 }
Jamie Madill893ab082014-05-16 16:56:10 -0400352
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000353 mResourceManager->deleteBuffer(buffer);
354}
355
356void Context::deleteShader(GLuint shader)
357{
358 mResourceManager->deleteShader(shader);
359}
360
361void Context::deleteProgram(GLuint program)
362{
363 mResourceManager->deleteProgram(program);
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000364}
365
366void Context::deleteTexture(GLuint texture)
367{
368 if (mResourceManager->getTexture(texture))
369 {
370 detachTexture(texture);
371 }
372
373 mResourceManager->deleteTexture(texture);
374}
375
376void Context::deleteRenderbuffer(GLuint renderbuffer)
377{
378 if (mResourceManager->getRenderbuffer(renderbuffer))
379 {
380 detachRenderbuffer(renderbuffer);
381 }
Jamie Madill893ab082014-05-16 16:56:10 -0400382
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000383 mResourceManager->deleteRenderbuffer(renderbuffer);
384}
385
Jamie Madillcd055f82013-07-26 11:55:15 -0400386void Context::deleteFenceSync(GLsync fenceSync)
387{
388 // The spec specifies the underlying Fence object is not deleted until all current
389 // wait commands finish. However, since the name becomes invalid, we cannot query the fence,
390 // and since our API is currently designed for being called from a single thread, we can delete
391 // the fence immediately.
Minmin Gong794e0002015-04-07 18:31:54 -0700392 mResourceManager->deleteFenceSync(static_cast<GLuint>(reinterpret_cast<uintptr_t>(fenceSync)));
Jamie Madillcd055f82013-07-26 11:55:15 -0400393}
394
Jamie Madill57a89722013-07-02 11:57:03 -0400395void Context::deleteVertexArray(GLuint vertexArray)
396{
397 auto vertexArrayObject = mVertexArrayMap.find(vertexArray);
398
399 if (vertexArrayObject != mVertexArrayMap.end())
400 {
401 detachVertexArray(vertexArray);
402
403 mVertexArrayHandleAllocator.release(vertexArrayObject->first);
404 delete vertexArrayObject->second;
405 mVertexArrayMap.erase(vertexArrayObject);
406 }
407}
408
Jamie Madilldc356042013-07-19 16:36:57 -0400409void Context::deleteSampler(GLuint sampler)
410{
411 if (mResourceManager->getSampler(sampler))
412 {
413 detachSampler(sampler);
414 }
415
416 mResourceManager->deleteSampler(sampler);
417}
418
Geoff Langc8058452014-02-03 12:04:11 -0500419void Context::deleteTransformFeedback(GLuint transformFeedback)
420{
Jamie Madill5fd0b2d2015-01-05 13:38:44 -0500421 auto iter = mTransformFeedbackMap.find(transformFeedback);
Geoff Langc8058452014-02-03 12:04:11 -0500422 if (iter != mTransformFeedbackMap.end())
423 {
424 detachTransformFeedback(transformFeedback);
425 mTransformFeedbackAllocator.release(transformFeedback);
426 iter->second->release();
427 mTransformFeedbackMap.erase(iter);
428 }
429}
430
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000431void Context::deleteFramebuffer(GLuint framebuffer)
432{
433 FramebufferMap::iterator framebufferObject = mFramebufferMap.find(framebuffer);
434
435 if (framebufferObject != mFramebufferMap.end())
436 {
437 detachFramebuffer(framebuffer);
438
439 mFramebufferHandleAllocator.release(framebufferObject->first);
440 delete framebufferObject->second;
441 mFramebufferMap.erase(framebufferObject);
442 }
443}
444
Jamie Madill33dc8432013-07-26 11:55:05 -0400445void Context::deleteFenceNV(GLuint fence)
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000446{
Jamie Madill33dc8432013-07-26 11:55:05 -0400447 FenceNVMap::iterator fenceObject = mFenceNVMap.find(fence);
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000448
Jamie Madill33dc8432013-07-26 11:55:05 -0400449 if (fenceObject != mFenceNVMap.end())
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000450 {
Jamie Madill33dc8432013-07-26 11:55:05 -0400451 mFenceNVHandleAllocator.release(fenceObject->first);
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000452 delete fenceObject->second;
Jamie Madill33dc8432013-07-26 11:55:05 -0400453 mFenceNVMap.erase(fenceObject);
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000454 }
455}
456
457void Context::deleteQuery(GLuint query)
458{
459 QueryMap::iterator queryObject = mQueryMap.find(query);
460 if (queryObject != mQueryMap.end())
461 {
462 mQueryHandleAllocator.release(queryObject->first);
463 if (queryObject->second)
464 {
465 queryObject->second->release();
466 }
467 mQueryMap.erase(queryObject);
468 }
469}
470
471Buffer *Context::getBuffer(GLuint handle)
472{
473 return mResourceManager->getBuffer(handle);
474}
475
Geoff Lang48dcae72014-02-05 16:28:24 -0500476Shader *Context::getShader(GLuint handle) const
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000477{
478 return mResourceManager->getShader(handle);
479}
480
Geoff Lang48dcae72014-02-05 16:28:24 -0500481Program *Context::getProgram(GLuint handle) const
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000482{
483 return mResourceManager->getProgram(handle);
484}
485
Jamie Madill570f7c82014-07-03 10:38:54 -0400486Texture *Context::getTexture(GLuint handle) const
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000487{
488 return mResourceManager->getTexture(handle);
489}
490
Jamie Madill6c7b4ad2014-06-16 10:33:59 -0400491Renderbuffer *Context::getRenderbuffer(GLuint handle)
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000492{
493 return mResourceManager->getRenderbuffer(handle);
494}
495
Jamie Madillcd055f82013-07-26 11:55:15 -0400496FenceSync *Context::getFenceSync(GLsync handle) const
497{
Minmin Gong794e0002015-04-07 18:31:54 -0700498 return mResourceManager->getFenceSync(static_cast<GLuint>(reinterpret_cast<uintptr_t>(handle)));
Jamie Madillcd055f82013-07-26 11:55:15 -0400499}
500
Jamie Madill57a89722013-07-02 11:57:03 -0400501VertexArray *Context::getVertexArray(GLuint handle) const
502{
503 auto vertexArray = mVertexArrayMap.find(handle);
504
505 if (vertexArray == mVertexArrayMap.end())
506 {
507 return NULL;
508 }
509 else
510 {
511 return vertexArray->second;
512 }
513}
514
Jamie Madilldc356042013-07-19 16:36:57 -0400515Sampler *Context::getSampler(GLuint handle) const
516{
517 return mResourceManager->getSampler(handle);
518}
519
Geoff Langc8058452014-02-03 12:04:11 -0500520TransformFeedback *Context::getTransformFeedback(GLuint handle) const
521{
522 if (handle == 0)
523 {
524 return mTransformFeedbackZero.get();
525 }
526 else
527 {
528 TransformFeedbackMap::const_iterator iter = mTransformFeedbackMap.find(handle);
529 return (iter != mTransformFeedbackMap.end()) ? iter->second : NULL;
530 }
531}
532
Jamie Madilldc356042013-07-19 16:36:57 -0400533bool Context::isSampler(GLuint samplerName) const
534{
535 return mResourceManager->isSampler(samplerName);
536}
537
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000538void Context::bindArrayBuffer(unsigned int buffer)
539{
540 mResourceManager->checkBufferAllocation(buffer);
541
Shannon Woods53a94a82014-06-24 15:20:36 -0400542 mState.setArrayBufferBinding(getBuffer(buffer));
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000543}
544
545void Context::bindElementArrayBuffer(unsigned int buffer)
546{
547 mResourceManager->checkBufferAllocation(buffer);
548
Shannon Woods53a94a82014-06-24 15:20:36 -0400549 mState.getVertexArray()->setElementArrayBuffer(getBuffer(buffer));
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000550}
551
Jamie Madilldedd7b92014-11-05 16:30:36 -0500552void Context::bindTexture(GLenum target, GLuint handle)
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000553{
Jamie Madilldedd7b92014-11-05 16:30:36 -0500554 Texture *texture = NULL;
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000555
Jamie Madilldedd7b92014-11-05 16:30:36 -0500556 if (handle == 0)
557 {
558 texture = mZeroTextures[target].get();
559 }
560 else
561 {
562 mResourceManager->checkTextureAllocation(handle, target);
563 texture = getTexture(handle);
564 }
565
566 ASSERT(texture);
567
568 mState.setSamplerTexture(target, texture);
shannon.woods%transgaming.com@gtempaccount.com90dbc442013-04-13 03:46:14 +0000569}
570
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000571void Context::bindReadFramebuffer(GLuint framebuffer)
572{
573 if (!getFramebuffer(framebuffer))
574 {
Jamie Madilld1405e52015-03-05 15:41:39 -0500575 mFramebufferMap[framebuffer] = new Framebuffer(mCaps, mRenderer, framebuffer);
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000576 }
577
Shannon Woods53a94a82014-06-24 15:20:36 -0400578 mState.setReadFramebufferBinding(getFramebuffer(framebuffer));
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000579}
580
581void Context::bindDrawFramebuffer(GLuint framebuffer)
582{
583 if (!getFramebuffer(framebuffer))
584 {
Jamie Madilld1405e52015-03-05 15:41:39 -0500585 mFramebufferMap[framebuffer] = new Framebuffer(mCaps, mRenderer, framebuffer);
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000586 }
587
Shannon Woods53a94a82014-06-24 15:20:36 -0400588 mState.setDrawFramebufferBinding(getFramebuffer(framebuffer));
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000589}
590
591void Context::bindRenderbuffer(GLuint renderbuffer)
592{
593 mResourceManager->checkRenderbufferAllocation(renderbuffer);
594
Shannon Woods53a94a82014-06-24 15:20:36 -0400595 mState.setRenderbufferBinding(getRenderbuffer(renderbuffer));
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000596}
597
Jamie Madill57a89722013-07-02 11:57:03 -0400598void Context::bindVertexArray(GLuint vertexArray)
599{
600 if (!getVertexArray(vertexArray))
601 {
Jamie Madill8e344942015-07-09 14:22:07 -0400602 VertexArray *vertexArrayObject = new VertexArray(mRenderer, vertexArray, MAX_VERTEX_ATTRIBS);
Shannon Woodsaa2ab7d2014-06-24 17:51:51 -0400603 mVertexArrayMap[vertexArray] = vertexArrayObject;
Jamie Madill57a89722013-07-02 11:57:03 -0400604 }
605
Shannon Woods53a94a82014-06-24 15:20:36 -0400606 mState.setVertexArrayBinding(getVertexArray(vertexArray));
Jamie Madill57a89722013-07-02 11:57:03 -0400607}
608
Jamie Madilldc356042013-07-19 16:36:57 -0400609void Context::bindSampler(GLuint textureUnit, GLuint sampler)
610{
Geoff Lang76b10c92014-09-05 16:28:14 -0400611 ASSERT(textureUnit < mCaps.maxCombinedTextureImageUnits);
Jamie Madilldc356042013-07-19 16:36:57 -0400612 mResourceManager->checkSamplerAllocation(sampler);
613
Shannon Woods53a94a82014-06-24 15:20:36 -0400614 mState.setSamplerBinding(textureUnit, getSampler(sampler));
Jamie Madilldc356042013-07-19 16:36:57 -0400615}
616
shannon.woods%transgaming.com@gtempaccount.com667a29c2013-04-13 03:39:04 +0000617void Context::bindGenericUniformBuffer(GLuint buffer)
618{
619 mResourceManager->checkBufferAllocation(buffer);
620
Shannon Woods53a94a82014-06-24 15:20:36 -0400621 mState.setGenericUniformBufferBinding(getBuffer(buffer));
shannon.woods%transgaming.com@gtempaccount.com667a29c2013-04-13 03:39:04 +0000622}
623
624void Context::bindIndexedUniformBuffer(GLuint buffer, GLuint index, GLintptr offset, GLsizeiptr size)
shannon.woods%transgaming.com@gtempaccount.com34089352013-04-13 03:36:57 +0000625{
626 mResourceManager->checkBufferAllocation(buffer);
627
Shannon Woods53a94a82014-06-24 15:20:36 -0400628 mState.setIndexedUniformBufferBinding(index, getBuffer(buffer), offset, size);
shannon.woods%transgaming.com@gtempaccount.com34089352013-04-13 03:36:57 +0000629}
630
shannon.woods%transgaming.com@gtempaccount.com667a29c2013-04-13 03:39:04 +0000631void Context::bindGenericTransformFeedbackBuffer(GLuint buffer)
632{
633 mResourceManager->checkBufferAllocation(buffer);
634
Geoff Lang045536b2015-03-27 15:17:18 -0400635 mState.getCurrentTransformFeedback()->bindGenericBuffer(getBuffer(buffer));
shannon.woods%transgaming.com@gtempaccount.com667a29c2013-04-13 03:39:04 +0000636}
637
638void Context::bindIndexedTransformFeedbackBuffer(GLuint buffer, GLuint index, GLintptr offset, GLsizeiptr size)
shannon.woods%transgaming.com@gtempaccount.com34089352013-04-13 03:36:57 +0000639{
640 mResourceManager->checkBufferAllocation(buffer);
641
Geoff Lang045536b2015-03-27 15:17:18 -0400642 mState.getCurrentTransformFeedback()->bindIndexedBuffer(index, getBuffer(buffer), offset, size);
shannon.woods%transgaming.com@gtempaccount.com34089352013-04-13 03:36:57 +0000643}
644
shannon.woods%transgaming.com@gtempaccount.com51171882013-04-13 03:39:10 +0000645void Context::bindCopyReadBuffer(GLuint buffer)
646{
647 mResourceManager->checkBufferAllocation(buffer);
648
Shannon Woods53a94a82014-06-24 15:20:36 -0400649 mState.setCopyReadBufferBinding(getBuffer(buffer));
shannon.woods%transgaming.com@gtempaccount.com51171882013-04-13 03:39:10 +0000650}
651
652void Context::bindCopyWriteBuffer(GLuint buffer)
653{
654 mResourceManager->checkBufferAllocation(buffer);
655
Shannon Woods53a94a82014-06-24 15:20:36 -0400656 mState.setCopyWriteBufferBinding(getBuffer(buffer));
shannon.woods%transgaming.com@gtempaccount.com51171882013-04-13 03:39:10 +0000657}
658
shannon.woods%transgaming.com@gtempaccount.comc926e5f2013-04-13 03:39:18 +0000659void Context::bindPixelPackBuffer(GLuint buffer)
660{
661 mResourceManager->checkBufferAllocation(buffer);
662
Shannon Woods53a94a82014-06-24 15:20:36 -0400663 mState.setPixelPackBufferBinding(getBuffer(buffer));
shannon.woods%transgaming.com@gtempaccount.comc926e5f2013-04-13 03:39:18 +0000664}
665
666void Context::bindPixelUnpackBuffer(GLuint buffer)
667{
668 mResourceManager->checkBufferAllocation(buffer);
669
Shannon Woods53a94a82014-06-24 15:20:36 -0400670 mState.setPixelUnpackBufferBinding(getBuffer(buffer));
shannon.woods%transgaming.com@gtempaccount.comc926e5f2013-04-13 03:39:18 +0000671}
672
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000673void Context::useProgram(GLuint program)
674{
Geoff Lang7dd2e102014-11-10 15:19:26 -0500675 mState.setProgram(getProgram(program));
daniel@transgaming.com95d29422012-07-24 18:36:10 +0000676}
677
Geoff Langc8058452014-02-03 12:04:11 -0500678void Context::bindTransformFeedback(GLuint transformFeedback)
679{
Shannon Woods53a94a82014-06-24 15:20:36 -0400680 mState.setTransformFeedbackBinding(getTransformFeedback(transformFeedback));
Geoff Langc8058452014-02-03 12:04:11 -0500681}
682
Geoff Lang5aad9672014-09-08 11:10:42 -0400683Error Context::beginQuery(GLenum target, GLuint query)
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000684{
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000685 Query *queryObject = getQuery(query, true, target);
Jamie Madilldb2f14c2014-05-13 13:56:30 -0400686 ASSERT(queryObject);
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000687
Geoff Lang5aad9672014-09-08 11:10:42 -0400688 // begin query
689 Error error = queryObject->begin();
690 if (error.isError())
691 {
692 return error;
693 }
694
695 // set query as active for specified target only if begin succeeded
Shannon Woods53a94a82014-06-24 15:20:36 -0400696 mState.setActiveQuery(target, queryObject);
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000697
Geoff Lang5aad9672014-09-08 11:10:42 -0400698 return Error(GL_NO_ERROR);
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000699}
700
Geoff Lang5aad9672014-09-08 11:10:42 -0400701Error Context::endQuery(GLenum target)
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000702{
Shannon Woods53a94a82014-06-24 15:20:36 -0400703 Query *queryObject = mState.getActiveQuery(target);
Jamie Madill45c785d2014-05-13 14:09:34 -0400704 ASSERT(queryObject);
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000705
Geoff Lang5aad9672014-09-08 11:10:42 -0400706 gl::Error error = queryObject->end();
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000707
Geoff Lang5aad9672014-09-08 11:10:42 -0400708 // Always unbind the query, even if there was an error. This may delete the query object.
Shannon Woods53a94a82014-06-24 15:20:36 -0400709 mState.setActiveQuery(target, NULL);
Geoff Lang5aad9672014-09-08 11:10:42 -0400710
711 return error;
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000712}
713
Jamie Madill1fc7e2c2014-01-21 16:47:10 -0500714Framebuffer *Context::getFramebuffer(unsigned int handle) const
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000715{
Jamie Madill1fc7e2c2014-01-21 16:47:10 -0500716 FramebufferMap::const_iterator framebuffer = mFramebufferMap.find(handle);
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000717
718 if (framebuffer == mFramebufferMap.end())
719 {
720 return NULL;
721 }
722 else
723 {
724 return framebuffer->second;
725 }
726}
727
Jamie Madill33dc8432013-07-26 11:55:05 -0400728FenceNV *Context::getFenceNV(unsigned int handle)
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000729{
Jamie Madill33dc8432013-07-26 11:55:05 -0400730 FenceNVMap::iterator fence = mFenceNVMap.find(handle);
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000731
Jamie Madill33dc8432013-07-26 11:55:05 -0400732 if (fence == mFenceNVMap.end())
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000733 {
734 return NULL;
735 }
736 else
737 {
738 return fence->second;
739 }
740}
741
742Query *Context::getQuery(unsigned int handle, bool create, GLenum type)
743{
744 QueryMap::iterator query = mQueryMap.find(handle);
745
746 if (query == mQueryMap.end())
747 {
748 return NULL;
749 }
750 else
751 {
752 if (!query->second && create)
753 {
Brandon Jones3b579e32014-08-08 10:54:25 -0700754 query->second = new Query(mRenderer->createQuery(type), handle);
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000755 query->second->addRef();
756 }
757 return query->second;
758 }
759}
760
Jamie Madill1fc7e2c2014-01-21 16:47:10 -0500761Texture *Context::getTargetTexture(GLenum target) const
762{
Geoff Lang691e58c2014-12-19 17:03:25 -0500763 ASSERT(ValidTextureTarget(this, target));
Jamie Madill1fc7e2c2014-01-21 16:47:10 -0500764
Geoff Lang691e58c2014-12-19 17:03:25 -0500765 return getSamplerTexture(mState.getActiveSampler(), target);
shannon.woods%transgaming.com@gtempaccount.comc926e5f2013-04-13 03:39:18 +0000766}
767
Geoff Lang76b10c92014-09-05 16:28:14 -0400768Texture *Context::getSamplerTexture(unsigned int sampler, GLenum type) const
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000769{
Jamie Madilldedd7b92014-11-05 16:30:36 -0500770 return mState.getSamplerTexture(sampler, type);
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000771}
772
Geoff Lang492a7e42014-11-05 13:27:06 -0500773Compiler *Context::getCompiler() const
774{
775 return mCompiler;
776}
777
Jamie Madill893ab082014-05-16 16:56:10 -0400778void Context::getBooleanv(GLenum pname, GLboolean *params)
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000779{
780 switch (pname)
781 {
daniel@transgaming.comf39967e2012-11-28 19:35:56 +0000782 case GL_SHADER_COMPILER: *params = GL_TRUE; break;
daniel@transgaming.comf39967e2012-11-28 19:35:56 +0000783 case GL_CONTEXT_ROBUST_ACCESS_EXT: *params = mRobustAccess ? GL_TRUE : GL_FALSE; break;
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000784 default:
Shannon Woods53a94a82014-06-24 15:20:36 -0400785 mState.getBooleanv(pname, params);
Jamie Madill893ab082014-05-16 16:56:10 -0400786 break;
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000787 }
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000788}
789
Jamie Madill893ab082014-05-16 16:56:10 -0400790void Context::getFloatv(GLenum pname, GLfloat *params)
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000791{
Shannon Woods53a94a82014-06-24 15:20:36 -0400792 // Queries about context capabilities and maximums are answered by Context.
793 // Queries about current GL state values are answered by State.
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000794 switch (pname)
795 {
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000796 case GL_ALIASED_LINE_WIDTH_RANGE:
Geoff Langc0b9ef42014-07-02 10:02:37 -0400797 params[0] = mCaps.minAliasedLineWidth;
798 params[1] = mCaps.maxAliasedLineWidth;
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000799 break;
800 case GL_ALIASED_POINT_SIZE_RANGE:
Geoff Langc0b9ef42014-07-02 10:02:37 -0400801 params[0] = mCaps.minAliasedPointSize;
802 params[1] = mCaps.maxAliasedPointSize;
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000803 break;
daniel@transgaming.com07ab8412012-07-12 15:17:09 +0000804 case GL_MAX_TEXTURE_MAX_ANISOTROPY_EXT:
Geoff Langc0b9ef42014-07-02 10:02:37 -0400805 ASSERT(mExtensions.textureFilterAnisotropic);
806 *params = mExtensions.maxTextureAnisotropy;
daniel@transgaming.com07ab8412012-07-12 15:17:09 +0000807 break;
Geoff Lange6d4e122015-06-29 13:33:55 -0400808 case GL_MAX_TEXTURE_LOD_BIAS:
809 *params = mCaps.maxLODBias;
810 break;
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000811 default:
Shannon Woods53a94a82014-06-24 15:20:36 -0400812 mState.getFloatv(pname, params);
Jamie Madill893ab082014-05-16 16:56:10 -0400813 break;
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000814 }
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000815}
816
Jamie Madill893ab082014-05-16 16:56:10 -0400817void Context::getIntegerv(GLenum pname, GLint *params)
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000818{
Shannon Woods53a94a82014-06-24 15:20:36 -0400819 // Queries about context capabilities and maximums are answered by Context.
820 // Queries about current GL state values are answered by State.
shannon.woods%transgaming.com@gtempaccount.combc373e52013-04-13 03:31:23 +0000821
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000822 switch (pname)
823 {
Geoff Lang301d1612014-07-09 10:34:37 -0400824 case GL_MAX_VERTEX_ATTRIBS: *params = mCaps.maxVertexAttributes; break;
825 case GL_MAX_VERTEX_UNIFORM_VECTORS: *params = mCaps.maxVertexUniformVectors; break;
826 case GL_MAX_VERTEX_UNIFORM_COMPONENTS: *params = mCaps.maxVertexUniformComponents; break;
Geoff Lang3a61c322014-07-10 13:01:54 -0400827 case GL_MAX_VARYING_VECTORS: *params = mCaps.maxVaryingVectors; break;
828 case GL_MAX_VARYING_COMPONENTS: *params = mCaps.maxVertexOutputComponents; break;
829 case GL_MAX_COMBINED_TEXTURE_IMAGE_UNITS: *params = mCaps.maxCombinedTextureImageUnits; break;
Geoff Lang301d1612014-07-09 10:34:37 -0400830 case GL_MAX_VERTEX_TEXTURE_IMAGE_UNITS: *params = mCaps.maxVertexTextureImageUnits; break;
831 case GL_MAX_TEXTURE_IMAGE_UNITS: *params = mCaps.maxTextureImageUnits; break;
832 case GL_MAX_FRAGMENT_UNIFORM_VECTORS: *params = mCaps.maxFragmentUniformVectors; break;
833 case GL_MAX_FRAGMENT_UNIFORM_COMPONENTS: *params = mCaps.maxFragmentInputComponents; break;
Geoff Langc0b9ef42014-07-02 10:02:37 -0400834 case GL_MAX_RENDERBUFFER_SIZE: *params = mCaps.maxRenderbufferSize; break;
835 case GL_MAX_COLOR_ATTACHMENTS_EXT: *params = mCaps.maxColorAttachments; break;
836 case GL_MAX_DRAW_BUFFERS_EXT: *params = mCaps.maxDrawBuffers; break;
Jamie Madill1caff072013-07-19 16:36:56 -0400837 //case GL_FRAMEBUFFER_BINDING: // now equivalent to GL_DRAW_FRAMEBUFFER_BINDING_ANGLE
Jamie Madill1caff072013-07-19 16:36:56 -0400838 case GL_SUBPIXEL_BITS: *params = 4; break;
Geoff Langc0b9ef42014-07-02 10:02:37 -0400839 case GL_MAX_TEXTURE_SIZE: *params = mCaps.max2DTextureSize; break;
840 case GL_MAX_CUBE_MAP_TEXTURE_SIZE: *params = mCaps.maxCubeMapTextureSize; break;
841 case GL_MAX_3D_TEXTURE_SIZE: *params = mCaps.max3DTextureSize; break;
842 case GL_MAX_ARRAY_TEXTURE_LAYERS: *params = mCaps.maxArrayTextureLayers; break;
Geoff Lang3a61c322014-07-10 13:01:54 -0400843 case GL_UNIFORM_BUFFER_OFFSET_ALIGNMENT: *params = mCaps.uniformBufferOffsetAlignment; break;
844 case GL_MAX_UNIFORM_BUFFER_BINDINGS: *params = mCaps.maxUniformBufferBindings; break;
Geoff Lang301d1612014-07-09 10:34:37 -0400845 case GL_MAX_VERTEX_UNIFORM_BLOCKS: *params = mCaps.maxVertexUniformBlocks; break;
846 case GL_MAX_FRAGMENT_UNIFORM_BLOCKS: *params = mCaps.maxFragmentUniformBlocks; break;
Geoff Lang3a61c322014-07-10 13:01:54 -0400847 case GL_MAX_COMBINED_UNIFORM_BLOCKS: *params = mCaps.maxCombinedTextureImageUnits; break;
Geoff Lange6d4e122015-06-29 13:33:55 -0400848 case GL_MAX_VERTEX_OUTPUT_COMPONENTS: *params = mCaps.maxVertexOutputComponents; break;
849 case GL_MAX_FRAGMENT_INPUT_COMPONENTS: *params = mCaps.maxFragmentInputComponents; break;
850 case GL_MIN_PROGRAM_TEXEL_OFFSET: *params = mCaps.minProgramTexelOffset; break;
851 case GL_MAX_PROGRAM_TEXEL_OFFSET: *params = mCaps.maxProgramTexelOffset; break;
Jamie Madillee7010d2013-10-17 10:45:47 -0400852 case GL_MAJOR_VERSION: *params = mClientVersion; break;
853 case GL_MINOR_VERSION: *params = 0; break;
Geoff Lang900013c2014-07-07 11:32:19 -0400854 case GL_MAX_ELEMENTS_INDICES: *params = mCaps.maxElementsIndices; break;
855 case GL_MAX_ELEMENTS_VERTICES: *params = mCaps.maxElementsVertices; break;
Geoff Lang05881a02014-07-10 14:05:30 -0400856 case GL_MAX_TRANSFORM_FEEDBACK_INTERLEAVED_COMPONENTS: *params = mCaps.maxTransformFeedbackInterleavedComponents; break;
857 case GL_MAX_TRANSFORM_FEEDBACK_SEPARATE_ATTRIBS: *params = mCaps.maxTransformFeedbackSeparateAttributes; break;
858 case GL_MAX_TRANSFORM_FEEDBACK_SEPARATE_COMPONENTS: *params = mCaps.maxTransformFeedbackSeparateComponents; break;
Cooper Partin4d61f7e2015-08-12 10:56:50 -0700859 case GL_NUM_COMPRESSED_TEXTURE_FORMATS:
860 *params = static_cast<GLint>(mCaps.compressedTextureFormats.size());
861 break;
Geoff Langdef624b2015-04-13 10:46:56 -0400862 case GL_MAX_SAMPLES_ANGLE: *params = mCaps.maxSamples; break;
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000863 case GL_MAX_VIEWPORT_DIMS:
864 {
Geoff Langc0b9ef42014-07-02 10:02:37 -0400865 params[0] = mCaps.maxViewportWidth;
866 params[1] = mCaps.maxViewportHeight;
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000867 }
868 break;
869 case GL_COMPRESSED_TEXTURE_FORMATS:
Geoff Lang900013c2014-07-07 11:32:19 -0400870 std::copy(mCaps.compressedTextureFormats.begin(), mCaps.compressedTextureFormats.end(), params);
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000871 break;
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000872 case GL_RESET_NOTIFICATION_STRATEGY_EXT:
873 *params = mResetStrategy;
874 break;
Geoff Lang900013c2014-07-07 11:32:19 -0400875 case GL_NUM_SHADER_BINARY_FORMATS:
Cooper Partin4d61f7e2015-08-12 10:56:50 -0700876 *params = static_cast<GLint>(mCaps.shaderBinaryFormats.size());
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000877 break;
Geoff Lang900013c2014-07-07 11:32:19 -0400878 case GL_SHADER_BINARY_FORMATS:
879 std::copy(mCaps.shaderBinaryFormats.begin(), mCaps.shaderBinaryFormats.end(), params);
880 break;
881 case GL_NUM_PROGRAM_BINARY_FORMATS:
Cooper Partin4d61f7e2015-08-12 10:56:50 -0700882 *params = static_cast<GLint>(mCaps.programBinaryFormats.size());
Geoff Lang900013c2014-07-07 11:32:19 -0400883 break;
884 case GL_PROGRAM_BINARY_FORMATS:
885 std::copy(mCaps.programBinaryFormats.begin(), mCaps.programBinaryFormats.end(), params);
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000886 break;
Geoff Lang23c81692013-08-12 10:46:58 -0400887 case GL_NUM_EXTENSIONS:
Geoff Langcec35902014-04-16 10:52:36 -0400888 *params = static_cast<GLint>(mExtensionStrings.size());
Geoff Lang23c81692013-08-12 10:46:58 -0400889 break;
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000890 default:
Jamie Madill48faf802014-11-06 15:27:22 -0500891 mState.getIntegerv(getData(), pname, params);
Jamie Madill893ab082014-05-16 16:56:10 -0400892 break;
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000893 }
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000894}
895
Jamie Madill893ab082014-05-16 16:56:10 -0400896void Context::getInteger64v(GLenum pname, GLint64 *params)
Jamie Madill0fda9862013-07-19 16:36:55 -0400897{
Shannon Woods53a94a82014-06-24 15:20:36 -0400898 // Queries about context capabilities and maximums are answered by Context.
899 // Queries about current GL state values are answered by State.
Jamie Madill0fda9862013-07-19 16:36:55 -0400900 switch (pname)
901 {
902 case GL_MAX_ELEMENT_INDEX:
Geoff Langc0b9ef42014-07-02 10:02:37 -0400903 *params = mCaps.maxElementIndex;
Jamie Madill0fda9862013-07-19 16:36:55 -0400904 break;
905 case GL_MAX_UNIFORM_BLOCK_SIZE:
Geoff Lang3a61c322014-07-10 13:01:54 -0400906 *params = mCaps.maxUniformBlockSize;
Jamie Madill0fda9862013-07-19 16:36:55 -0400907 break;
908 case GL_MAX_COMBINED_VERTEX_UNIFORM_COMPONENTS:
Geoff Lang3a61c322014-07-10 13:01:54 -0400909 *params = mCaps.maxCombinedVertexUniformComponents;
Jamie Madill0fda9862013-07-19 16:36:55 -0400910 break;
911 case GL_MAX_COMBINED_FRAGMENT_UNIFORM_COMPONENTS:
Geoff Lang3a61c322014-07-10 13:01:54 -0400912 *params = mCaps.maxCombinedFragmentUniformComponents;
Jamie Madill0fda9862013-07-19 16:36:55 -0400913 break;
914 case GL_MAX_SERVER_WAIT_TIMEOUT:
Geoff Lang900013c2014-07-07 11:32:19 -0400915 *params = mCaps.maxServerWaitTimeout;
Jamie Madill0fda9862013-07-19 16:36:55 -0400916 break;
917 default:
Jamie Madill893ab082014-05-16 16:56:10 -0400918 UNREACHABLE();
919 break;
Jamie Madill0fda9862013-07-19 16:36:55 -0400920 }
Jamie Madill0fda9862013-07-19 16:36:55 -0400921}
922
Shannon Woods1b2fb852013-08-19 14:28:48 -0400923bool Context::getIndexedIntegerv(GLenum target, GLuint index, GLint *data)
924{
Shannon Woods53a94a82014-06-24 15:20:36 -0400925 // Queries about context capabilities and maximums are answered by Context.
926 // Queries about current GL state values are answered by State.
Jamie Madill77a72f62015-04-14 11:18:32 -0400927 // Indexed integer queries all refer to current state, so this function is a
Shannon Woods53a94a82014-06-24 15:20:36 -0400928 // mere passthrough.
929 return mState.getIndexedIntegerv(target, index, data);
Shannon Woods1b2fb852013-08-19 14:28:48 -0400930}
931
932bool Context::getIndexedInteger64v(GLenum target, GLuint index, GLint64 *data)
933{
Shannon Woods53a94a82014-06-24 15:20:36 -0400934 // Queries about context capabilities and maximums are answered by Context.
935 // Queries about current GL state values are answered by State.
Jamie Madill77a72f62015-04-14 11:18:32 -0400936 // Indexed integer queries all refer to current state, so this function is a
Shannon Woods53a94a82014-06-24 15:20:36 -0400937 // mere passthrough.
938 return mState.getIndexedInteger64v(target, index, data);
Shannon Woods1b2fb852013-08-19 14:28:48 -0400939}
940
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000941bool Context::getQueryParameterInfo(GLenum pname, GLenum *type, unsigned int *numParams)
942{
shannon.woods%transgaming.com@gtempaccount.combc373e52013-04-13 03:31:23 +0000943 if (pname >= GL_DRAW_BUFFER0_EXT && pname <= GL_DRAW_BUFFER15_EXT)
944 {
945 *type = GL_INT;
946 *numParams = 1;
947 return true;
948 }
949
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000950 // Please note: the query type returned for DEPTH_CLEAR_VALUE in this implementation
951 // is FLOAT rather than INT, as would be suggested by the GL ES 2.0 spec. This is due
952 // to the fact that it is stored internally as a float, and so would require conversion
Jamie Madill893ab082014-05-16 16:56:10 -0400953 // if returned from Context::getIntegerv. Since this conversion is already implemented
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000954 // in the case that one calls glGetIntegerv to retrieve a float-typed state variable, we
955 // place DEPTH_CLEAR_VALUE with the floats. This should make no difference to the calling
956 // application.
957 switch (pname)
958 {
959 case GL_COMPRESSED_TEXTURE_FORMATS:
960 {
961 *type = GL_INT;
Cooper Partin4d61f7e2015-08-12 10:56:50 -0700962 *numParams = static_cast<unsigned int>(mCaps.compressedTextureFormats.size());
Geoff Lang900013c2014-07-07 11:32:19 -0400963 }
964 return true;
965 case GL_PROGRAM_BINARY_FORMATS_OES:
966 {
967 *type = GL_INT;
Cooper Partin4d61f7e2015-08-12 10:56:50 -0700968 *numParams = static_cast<unsigned int>(mCaps.programBinaryFormats.size());
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000969 }
shannon.woods%transgaming.com@gtempaccount.com667a29c2013-04-13 03:39:04 +0000970 return true;
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000971 case GL_SHADER_BINARY_FORMATS:
972 {
973 *type = GL_INT;
Cooper Partin4d61f7e2015-08-12 10:56:50 -0700974 *numParams = static_cast<unsigned int>(mCaps.shaderBinaryFormats.size());
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000975 }
shannon.woods%transgaming.com@gtempaccount.com667a29c2013-04-13 03:39:04 +0000976 return true;
Jamie Madillb9293972015-02-19 11:07:54 -0500977
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000978 case GL_MAX_VERTEX_ATTRIBS:
979 case GL_MAX_VERTEX_UNIFORM_VECTORS:
980 case GL_MAX_VARYING_VECTORS:
981 case GL_MAX_COMBINED_TEXTURE_IMAGE_UNITS:
982 case GL_MAX_VERTEX_TEXTURE_IMAGE_UNITS:
983 case GL_MAX_TEXTURE_IMAGE_UNITS:
984 case GL_MAX_FRAGMENT_UNIFORM_VECTORS:
985 case GL_MAX_RENDERBUFFER_SIZE:
shannon.woods%transgaming.com@gtempaccount.com9790c472013-04-13 03:28:23 +0000986 case GL_MAX_COLOR_ATTACHMENTS_EXT:
shannon.woods%transgaming.com@gtempaccount.combc373e52013-04-13 03:31:23 +0000987 case GL_MAX_DRAW_BUFFERS_EXT:
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000988 case GL_NUM_SHADER_BINARY_FORMATS:
989 case GL_NUM_COMPRESSED_TEXTURE_FORMATS:
990 case GL_ARRAY_BUFFER_BINDING:
Vladimir Vukicevic1e514352014-05-13 15:53:06 -0700991 //case GL_FRAMEBUFFER_BINDING: // equivalent to DRAW_FRAMEBUFFER_BINDING_ANGLE
992 case GL_DRAW_FRAMEBUFFER_BINDING_ANGLE:
993 case GL_READ_FRAMEBUFFER_BINDING_ANGLE:
apatrick@chromium.org144f2802012-07-12 01:42:34 +0000994 case GL_RENDERBUFFER_BINDING:
995 case GL_CURRENT_PROGRAM:
996 case GL_PACK_ALIGNMENT:
997 case GL_PACK_REVERSE_ROW_ORDER_ANGLE:
998 case GL_UNPACK_ALIGNMENT:
999 case GL_GENERATE_MIPMAP_HINT:
1000 case GL_FRAGMENT_SHADER_DERIVATIVE_HINT_OES:
1001 case GL_RED_BITS:
1002 case GL_GREEN_BITS:
1003 case GL_BLUE_BITS:
1004 case GL_ALPHA_BITS:
1005 case GL_DEPTH_BITS:
1006 case GL_STENCIL_BITS:
1007 case GL_ELEMENT_ARRAY_BUFFER_BINDING:
1008 case GL_CULL_FACE_MODE:
1009 case GL_FRONT_FACE:
1010 case GL_ACTIVE_TEXTURE:
1011 case GL_STENCIL_FUNC:
1012 case GL_STENCIL_VALUE_MASK:
1013 case GL_STENCIL_REF:
1014 case GL_STENCIL_FAIL:
1015 case GL_STENCIL_PASS_DEPTH_FAIL:
1016 case GL_STENCIL_PASS_DEPTH_PASS:
1017 case GL_STENCIL_BACK_FUNC:
1018 case GL_STENCIL_BACK_VALUE_MASK:
1019 case GL_STENCIL_BACK_REF:
1020 case GL_STENCIL_BACK_FAIL:
1021 case GL_STENCIL_BACK_PASS_DEPTH_FAIL:
1022 case GL_STENCIL_BACK_PASS_DEPTH_PASS:
1023 case GL_DEPTH_FUNC:
1024 case GL_BLEND_SRC_RGB:
1025 case GL_BLEND_SRC_ALPHA:
1026 case GL_BLEND_DST_RGB:
1027 case GL_BLEND_DST_ALPHA:
1028 case GL_BLEND_EQUATION_RGB:
1029 case GL_BLEND_EQUATION_ALPHA:
1030 case GL_STENCIL_WRITEMASK:
1031 case GL_STENCIL_BACK_WRITEMASK:
1032 case GL_STENCIL_CLEAR_VALUE:
1033 case GL_SUBPIXEL_BITS:
1034 case GL_MAX_TEXTURE_SIZE:
1035 case GL_MAX_CUBE_MAP_TEXTURE_SIZE:
1036 case GL_SAMPLE_BUFFERS:
1037 case GL_SAMPLES:
1038 case GL_IMPLEMENTATION_COLOR_READ_TYPE:
1039 case GL_IMPLEMENTATION_COLOR_READ_FORMAT:
1040 case GL_TEXTURE_BINDING_2D:
1041 case GL_TEXTURE_BINDING_CUBE_MAP:
1042 case GL_RESET_NOTIFICATION_STRATEGY_EXT:
1043 case GL_NUM_PROGRAM_BINARY_FORMATS_OES:
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001044 {
1045 *type = GL_INT;
1046 *numParams = 1;
1047 }
shannon.woods%transgaming.com@gtempaccount.com667a29c2013-04-13 03:39:04 +00001048 return true;
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001049 case GL_MAX_SAMPLES_ANGLE:
1050 {
Geoff Langc0b9ef42014-07-02 10:02:37 -04001051 if (mExtensions.framebufferMultisample)
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001052 {
1053 *type = GL_INT;
1054 *numParams = 1;
1055 }
1056 else
1057 {
1058 return false;
1059 }
1060 }
shannon.woods%transgaming.com@gtempaccount.com667a29c2013-04-13 03:39:04 +00001061 return true;
Shannon Woods158c4382014-05-06 13:00:07 -04001062 case GL_PIXEL_PACK_BUFFER_BINDING:
1063 case GL_PIXEL_UNPACK_BUFFER_BINDING:
1064 {
Geoff Langc0b9ef42014-07-02 10:02:37 -04001065 if (mExtensions.pixelBufferObject)
Shannon Woods158c4382014-05-06 13:00:07 -04001066 {
1067 *type = GL_INT;
1068 *numParams = 1;
1069 }
1070 else
1071 {
1072 return false;
1073 }
1074 }
1075 return true;
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001076 case GL_MAX_VIEWPORT_DIMS:
1077 {
1078 *type = GL_INT;
1079 *numParams = 2;
1080 }
shannon.woods%transgaming.com@gtempaccount.com667a29c2013-04-13 03:39:04 +00001081 return true;
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001082 case GL_VIEWPORT:
1083 case GL_SCISSOR_BOX:
1084 {
1085 *type = GL_INT;
1086 *numParams = 4;
1087 }
shannon.woods%transgaming.com@gtempaccount.com667a29c2013-04-13 03:39:04 +00001088 return true;
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001089 case GL_SHADER_COMPILER:
1090 case GL_SAMPLE_COVERAGE_INVERT:
1091 case GL_DEPTH_WRITEMASK:
1092 case GL_CULL_FACE: // CULL_FACE through DITHER are natural to IsEnabled,
1093 case GL_POLYGON_OFFSET_FILL: // but can be retrieved through the Get{Type}v queries.
1094 case GL_SAMPLE_ALPHA_TO_COVERAGE: // For this purpose, they are treated here as bool-natural
1095 case GL_SAMPLE_COVERAGE:
1096 case GL_SCISSOR_TEST:
1097 case GL_STENCIL_TEST:
1098 case GL_DEPTH_TEST:
1099 case GL_BLEND:
1100 case GL_DITHER:
1101 case GL_CONTEXT_ROBUST_ACCESS_EXT:
1102 {
1103 *type = GL_BOOL;
1104 *numParams = 1;
1105 }
shannon.woods%transgaming.com@gtempaccount.com667a29c2013-04-13 03:39:04 +00001106 return true;
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001107 case GL_COLOR_WRITEMASK:
1108 {
1109 *type = GL_BOOL;
1110 *numParams = 4;
1111 }
shannon.woods%transgaming.com@gtempaccount.com667a29c2013-04-13 03:39:04 +00001112 return true;
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001113 case GL_POLYGON_OFFSET_FACTOR:
1114 case GL_POLYGON_OFFSET_UNITS:
1115 case GL_SAMPLE_COVERAGE_VALUE:
1116 case GL_DEPTH_CLEAR_VALUE:
1117 case GL_LINE_WIDTH:
1118 {
1119 *type = GL_FLOAT;
1120 *numParams = 1;
1121 }
shannon.woods%transgaming.com@gtempaccount.com667a29c2013-04-13 03:39:04 +00001122 return true;
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001123 case GL_ALIASED_LINE_WIDTH_RANGE:
1124 case GL_ALIASED_POINT_SIZE_RANGE:
1125 case GL_DEPTH_RANGE:
1126 {
1127 *type = GL_FLOAT;
1128 *numParams = 2;
1129 }
shannon.woods%transgaming.com@gtempaccount.com667a29c2013-04-13 03:39:04 +00001130 return true;
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001131 case GL_COLOR_CLEAR_VALUE:
1132 case GL_BLEND_COLOR:
1133 {
1134 *type = GL_FLOAT;
1135 *numParams = 4;
1136 }
shannon.woods%transgaming.com@gtempaccount.com667a29c2013-04-13 03:39:04 +00001137 return true;
daniel@transgaming.com07ab8412012-07-12 15:17:09 +00001138 case GL_MAX_TEXTURE_MAX_ANISOTROPY_EXT:
Geoff Langc0b9ef42014-07-02 10:02:37 -04001139 if (!mExtensions.maxTextureAnisotropy)
daniel@transgaming.com07ab8412012-07-12 15:17:09 +00001140 {
1141 return false;
1142 }
1143 *type = GL_FLOAT;
1144 *numParams = 1;
shannon.woods%transgaming.com@gtempaccount.com667a29c2013-04-13 03:39:04 +00001145 return true;
1146 }
1147
1148 if (mClientVersion < 3)
1149 {
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001150 return false;
1151 }
1152
shannon.woods%transgaming.com@gtempaccount.com667a29c2013-04-13 03:39:04 +00001153 // Check for ES3.0+ parameter names
1154 switch (pname)
1155 {
shannonwoods@chromium.org97c3d502013-05-30 00:04:34 +00001156 case GL_MAX_UNIFORM_BUFFER_BINDINGS:
1157 case GL_UNIFORM_BUFFER_OFFSET_ALIGNMENT:
shannon.woods%transgaming.com@gtempaccount.com667a29c2013-04-13 03:39:04 +00001158 case GL_UNIFORM_BUFFER_BINDING:
1159 case GL_TRANSFORM_FEEDBACK_BINDING:
Geoff Lang045536b2015-03-27 15:17:18 -04001160 case GL_TRANSFORM_FEEDBACK_BUFFER_BINDING:
shannon.woods%transgaming.com@gtempaccount.com51171882013-04-13 03:39:10 +00001161 case GL_COPY_READ_BUFFER_BINDING:
1162 case GL_COPY_WRITE_BUFFER_BINDING:
shannon.woods%transgaming.com@gtempaccount.comc416e1c2013-04-13 03:45:05 +00001163 case GL_TEXTURE_BINDING_3D:
shannon.woods%transgaming.com@gtempaccount.com90dbc442013-04-13 03:46:14 +00001164 case GL_TEXTURE_BINDING_2D_ARRAY:
shannon.woods%transgaming.com@gtempaccount.comc1fdf6b2013-04-13 03:44:41 +00001165 case GL_MAX_3D_TEXTURE_SIZE:
shannon.woods%transgaming.com@gtempaccount.coma98a8112013-04-13 03:45:57 +00001166 case GL_MAX_ARRAY_TEXTURE_LAYERS:
shannonwoods@chromium.orgf2d76f82013-05-30 00:06:32 +00001167 case GL_MAX_VERTEX_UNIFORM_BLOCKS:
1168 case GL_MAX_FRAGMENT_UNIFORM_BLOCKS:
1169 case GL_MAX_COMBINED_UNIFORM_BLOCKS:
Geoff Lange6d4e122015-06-29 13:33:55 -04001170 case GL_MAX_VERTEX_OUTPUT_COMPONENTS:
1171 case GL_MAX_FRAGMENT_INPUT_COMPONENTS:
Geoff Langd3ff9002014-05-08 11:19:27 -04001172 case GL_MAX_VARYING_COMPONENTS:
Jamie Madillefb3bd12013-07-02 11:57:05 -04001173 case GL_VERTEX_ARRAY_BINDING:
Jamie Madill38850df2013-07-19 16:36:55 -04001174 case GL_MAX_VERTEX_UNIFORM_COMPONENTS:
1175 case GL_MAX_FRAGMENT_UNIFORM_COMPONENTS:
Geoff Lange6d4e122015-06-29 13:33:55 -04001176 case GL_MIN_PROGRAM_TEXEL_OFFSET:
1177 case GL_MAX_PROGRAM_TEXEL_OFFSET:
Geoff Lang23c81692013-08-12 10:46:58 -04001178 case GL_NUM_EXTENSIONS:
Jamie Madillee7010d2013-10-17 10:45:47 -04001179 case GL_MAJOR_VERSION:
1180 case GL_MINOR_VERSION:
Jamie Madill13a2f852013-12-11 16:35:08 -05001181 case GL_MAX_ELEMENTS_INDICES:
1182 case GL_MAX_ELEMENTS_VERTICES:
Geoff Lang1b6edcb2014-02-03 14:27:56 -05001183 case GL_MAX_TRANSFORM_FEEDBACK_INTERLEAVED_COMPONENTS:
Jamie Madill2e503552013-12-19 13:48:34 -05001184 case GL_MAX_TRANSFORM_FEEDBACK_SEPARATE_ATTRIBS:
Geoff Lang1b6edcb2014-02-03 14:27:56 -05001185 case GL_MAX_TRANSFORM_FEEDBACK_SEPARATE_COMPONENTS:
shannon.woods%transgaming.com@gtempaccount.com667a29c2013-04-13 03:39:04 +00001186 {
1187 *type = GL_INT;
1188 *numParams = 1;
1189 }
1190 return true;
Jamie Madill0fda9862013-07-19 16:36:55 -04001191
1192 case GL_MAX_ELEMENT_INDEX:
1193 case GL_MAX_UNIFORM_BLOCK_SIZE:
1194 case GL_MAX_COMBINED_VERTEX_UNIFORM_COMPONENTS:
1195 case GL_MAX_COMBINED_FRAGMENT_UNIFORM_COMPONENTS:
1196 case GL_MAX_SERVER_WAIT_TIMEOUT:
1197 {
1198 *type = GL_INT_64_ANGLEX;
1199 *numParams = 1;
1200 }
1201 return true;
Jamie Madill2e503552013-12-19 13:48:34 -05001202
1203 case GL_TRANSFORM_FEEDBACK_ACTIVE:
Geoff Lang1b6edcb2014-02-03 14:27:56 -05001204 case GL_TRANSFORM_FEEDBACK_PAUSED:
Jamie Madill2e503552013-12-19 13:48:34 -05001205 {
1206 *type = GL_BOOL;
1207 *numParams = 1;
1208 }
1209 return true;
Geoff Lange6d4e122015-06-29 13:33:55 -04001210
1211 case GL_MAX_TEXTURE_LOD_BIAS:
1212 {
1213 *type = GL_FLOAT;
1214 *numParams = 1;
1215 }
1216 return true;
shannon.woods%transgaming.com@gtempaccount.com667a29c2013-04-13 03:39:04 +00001217 }
1218
1219 return false;
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001220}
1221
Shannon Woods1b2fb852013-08-19 14:28:48 -04001222bool Context::getIndexedQueryParameterInfo(GLenum target, GLenum *type, unsigned int *numParams)
1223{
1224 if (mClientVersion < 3)
1225 {
1226 return false;
1227 }
1228
1229 switch (target)
1230 {
1231 case GL_TRANSFORM_FEEDBACK_BUFFER_BINDING:
1232 case GL_UNIFORM_BUFFER_BINDING:
1233 {
1234 *type = GL_INT;
1235 *numParams = 1;
1236 }
1237 return true;
1238 case GL_TRANSFORM_FEEDBACK_BUFFER_START:
1239 case GL_TRANSFORM_FEEDBACK_BUFFER_SIZE:
1240 case GL_UNIFORM_BUFFER_START:
1241 case GL_UNIFORM_BUFFER_SIZE:
1242 {
1243 *type = GL_INT_64_ANGLEX;
1244 *numParams = 1;
1245 }
1246 }
1247
1248 return false;
1249}
1250
Geoff Langc77e8c32014-09-08 16:28:24 -04001251Error Context::drawArrays(GLenum mode, GLint first, GLsizei count, GLsizei instances)
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001252{
Jamie Madill1b94d432015-08-07 13:23:23 -04001253 syncRendererState();
Geoff Lang520c4ae2015-05-05 13:12:36 -04001254 Error error = mRenderer->drawArrays(getData(), mode, first, count, instances);
1255 if (error.isError())
1256 {
1257 return error;
1258 }
1259
1260 TransformFeedback *transformFeedback = mState.getCurrentTransformFeedback();
1261 if (transformFeedback->isActive() && !transformFeedback->isPaused())
1262 {
1263 for (size_t tfBufferIndex = 0; tfBufferIndex < transformFeedback->getIndexedBufferCount(); tfBufferIndex++)
1264 {
1265 const OffsetBindingPointer<Buffer> &buffer = transformFeedback->getIndexedBuffer(tfBufferIndex);
1266 if (buffer.get() != nullptr)
1267 {
1268 buffer->onTransformFeedback();
1269 }
1270 }
1271 }
1272
1273 return Error(GL_NO_ERROR);
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001274}
1275
Geoff Langc77e8c32014-09-08 16:28:24 -04001276Error Context::drawElements(GLenum mode, GLsizei count, GLenum type,
1277 const GLvoid *indices, GLsizei instances,
Geoff Lang831b1952015-05-05 11:02:27 -04001278 const RangeUI &indexRange)
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001279{
Jamie Madill1b94d432015-08-07 13:23:23 -04001280 syncRendererState();
Jamie Madilld9e58302014-11-06 15:27:26 -05001281 return mRenderer->drawElements(getData(), mode, count, type, indices, instances, indexRange);
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001282}
1283
Geoff Lang129753a2015-01-09 16:52:09 -05001284Error Context::flush()
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001285{
Geoff Lang129753a2015-01-09 16:52:09 -05001286 return mRenderer->flush();
1287}
1288
1289Error Context::finish()
1290{
1291 return mRenderer->finish();
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001292}
1293
Austin Kinross6ee1e782015-05-29 17:05:37 -07001294void Context::insertEventMarker(GLsizei length, const char *marker)
1295{
1296 ASSERT(mRenderer);
1297 mRenderer->insertEventMarker(length, marker);
1298}
1299
1300void Context::pushGroupMarker(GLsizei length, const char *marker)
1301{
1302 ASSERT(mRenderer);
1303 mRenderer->pushGroupMarker(length, marker);
1304}
1305
1306void Context::popGroupMarker()
1307{
1308 ASSERT(mRenderer);
1309 mRenderer->popGroupMarker();
1310}
1311
Geoff Langda5777c2014-07-11 09:52:58 -04001312void Context::recordError(const Error &error)
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001313{
Geoff Langda5777c2014-07-11 09:52:58 -04001314 if (error.isError())
1315 {
1316 mErrors.insert(error.getCode());
1317 }
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001318}
1319
1320// Get one of the recorded errors and clear its flag, if any.
1321// [OpenGL ES 2.0.24] section 2.5 page 13.
1322GLenum Context::getError()
1323{
Geoff Langda5777c2014-07-11 09:52:58 -04001324 if (mErrors.empty())
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001325 {
Geoff Langda5777c2014-07-11 09:52:58 -04001326 return GL_NO_ERROR;
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001327 }
Geoff Langda5777c2014-07-11 09:52:58 -04001328 else
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001329 {
Geoff Langda5777c2014-07-11 09:52:58 -04001330 GLenum error = *mErrors.begin();
1331 mErrors.erase(mErrors.begin());
1332 return error;
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001333 }
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001334}
1335
1336GLenum Context::getResetStatus()
1337{
Jamie Madill93e13fb2014-11-06 15:27:25 -05001338 //TODO(jmadill): needs MANGLE reworking
shannon.woods@transgaming.comddd6c802013-02-28 23:05:14 +00001339 if (mResetStatus == GL_NO_ERROR && !mContextLost)
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001340 {
daniel@transgaming.comf688c0d2012-10-31 17:52:57 +00001341 // mResetStatus will be set by the markContextLost callback
1342 // in the case a notification is sent
Jamie Madill4c76fea2014-11-24 11:38:52 -05001343 if (mRenderer->testDeviceLost())
Jamie Madill9dd0cf02014-11-24 11:38:51 -05001344 {
1345 mRenderer->notifyDeviceLost();
1346 }
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001347 }
1348
1349 GLenum status = mResetStatus;
1350
1351 if (mResetStatus != GL_NO_ERROR)
1352 {
shannon.woods@transgaming.comddd6c802013-02-28 23:05:14 +00001353 ASSERT(mContextLost);
1354
daniel@transgaming.com621ce052012-10-31 17:52:29 +00001355 if (mRenderer->testDeviceResettable())
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001356 {
1357 mResetStatus = GL_NO_ERROR;
1358 }
1359 }
Jamie Madill893ab082014-05-16 16:56:10 -04001360
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001361 return status;
1362}
1363
1364bool Context::isResetNotificationEnabled()
1365{
1366 return (mResetStrategy == GL_LOSE_CONTEXT_ON_RESET_EXT);
1367}
1368
shannon.woods%transgaming.com@gtempaccount.comdaea4b42013-04-13 03:28:54 +00001369int Context::getClientVersion() const
1370{
1371 return mClientVersion;
1372}
1373
Corentin Walleze3b10e82015-05-20 11:06:25 -04001374const egl::Config *Context::getConfig() const
Régis Fénéon83107972015-02-05 12:57:44 +01001375{
Corentin Walleze3b10e82015-05-20 11:06:25 -04001376 return mConfig;
Régis Fénéon83107972015-02-05 12:57:44 +01001377}
1378
1379EGLenum Context::getClientType() const
1380{
1381 return mClientType;
1382}
1383
1384EGLenum Context::getRenderBuffer() const
1385{
Corentin Wallez37c39792015-08-20 14:19:46 -04001386 auto framebufferIt = mFramebufferMap.find(0);
1387 if (framebufferIt != mFramebufferMap.end())
1388 {
1389 const Framebuffer *framebuffer = framebufferIt->second;
1390 const FramebufferAttachment *backAttachment = framebuffer->getAttachment(GL_BACK);
1391
1392 ASSERT(backAttachment != nullptr);
1393 return backAttachment->getSurface()->getRenderBuffer();
1394 }
1395 else
1396 {
1397 return EGL_NONE;
1398 }
Régis Fénéon83107972015-02-05 12:57:44 +01001399}
1400
Geoff Langcec35902014-04-16 10:52:36 -04001401const Caps &Context::getCaps() const
1402{
Geoff Langc0b9ef42014-07-02 10:02:37 -04001403 return mCaps;
1404}
1405
1406const TextureCapsMap &Context::getTextureCaps() const
1407{
1408 return mTextureCaps;
1409}
1410
1411const Extensions &Context::getExtensions() const
1412{
1413 return mExtensions;
Geoff Langcec35902014-04-16 10:52:36 -04001414}
1415
Austin Kinross02df7962015-07-01 10:03:42 -07001416const Limitations &Context::getLimitations() const
1417{
1418 return mLimitations;
1419}
1420
Shannon Woods53a94a82014-06-24 15:20:36 -04001421void Context::detachTexture(GLuint texture)
1422{
1423 // Simple pass-through to State's detachTexture method, as textures do not require
1424 // allocation map management either here or in the resource manager at detach time.
1425 // Zero textures are held by the Context, and we don't attempt to request them from
1426 // the State.
Jamie Madille6382c32014-11-07 15:05:26 -05001427 mState.detachTexture(mZeroTextures, texture);
Shannon Woods53a94a82014-06-24 15:20:36 -04001428}
1429
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001430void Context::detachBuffer(GLuint buffer)
1431{
Jamie Madill77a72f62015-04-14 11:18:32 -04001432 // Buffer detachment is handled by Context, because the buffer must also be
Shannon Woods53a94a82014-06-24 15:20:36 -04001433 // attached from any VAOs in existence, and Context holds the VAO map.
1434
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001435 // [OpenGL ES 2.0.24] section 2.9 page 22:
1436 // If a buffer object is deleted while it is bound, all bindings to that object in the current context
1437 // (i.e. in the thread that called Delete-Buffers) are reset to zero.
1438
Shannon Woods53a94a82014-06-24 15:20:36 -04001439 mState.removeArrayBufferBinding(buffer);
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001440
Jamie Madill57a89722013-07-02 11:57:03 -04001441 // mark as freed among the vertex array objects
Jamie Madill77a90c22015-08-11 16:33:17 -04001442 for (auto &vaoPair : mVertexArrayMap)
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001443 {
Jamie Madill77a90c22015-08-11 16:33:17 -04001444 vaoPair.second->detachBuffer(buffer);
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001445 }
1446}
1447
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001448void Context::detachFramebuffer(GLuint framebuffer)
1449{
Shannon Woods53a94a82014-06-24 15:20:36 -04001450 // Framebuffer detachment is handled by Context, because 0 is a valid
1451 // Framebuffer object, and a pointer to it must be passed from Context
1452 // to State at binding time.
1453
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001454 // [OpenGL ES 2.0.24] section 4.4 page 107:
1455 // If a framebuffer that is currently bound to the target FRAMEBUFFER is deleted, it is as though
1456 // BindFramebuffer had been executed with the target of FRAMEBUFFER and framebuffer of zero.
1457
Gregoire Payen de La Garanderieed54e5d2015-03-17 16:51:24 +00001458 if (mState.removeReadFramebufferBinding(framebuffer) && framebuffer != 0)
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001459 {
1460 bindReadFramebuffer(0);
1461 }
1462
Gregoire Payen de La Garanderieed54e5d2015-03-17 16:51:24 +00001463 if (mState.removeDrawFramebufferBinding(framebuffer) && framebuffer != 0)
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001464 {
1465 bindDrawFramebuffer(0);
1466 }
1467}
1468
1469void Context::detachRenderbuffer(GLuint renderbuffer)
1470{
Shannon Woods53a94a82014-06-24 15:20:36 -04001471 mState.detachRenderbuffer(renderbuffer);
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001472}
1473
Jamie Madill57a89722013-07-02 11:57:03 -04001474void Context::detachVertexArray(GLuint vertexArray)
1475{
Jamie Madill77a72f62015-04-14 11:18:32 -04001476 // Vertex array detachment is handled by Context, because 0 is a valid
1477 // VAO, and a pointer to it must be passed from Context to State at
Shannon Woods53a94a82014-06-24 15:20:36 -04001478 // binding time.
1479
Jamie Madill57a89722013-07-02 11:57:03 -04001480 // [OpenGL ES 3.0.2] section 2.10 page 43:
1481 // If a vertex array object that is currently bound is deleted, the binding
1482 // for that object reverts to zero and the default vertex array becomes current.
Shannon Woods53a94a82014-06-24 15:20:36 -04001483 if (mState.removeVertexArrayBinding(vertexArray))
Jamie Madill57a89722013-07-02 11:57:03 -04001484 {
1485 bindVertexArray(0);
1486 }
1487}
1488
Geoff Langc8058452014-02-03 12:04:11 -05001489void Context::detachTransformFeedback(GLuint transformFeedback)
1490{
Shannon Woods53a94a82014-06-24 15:20:36 -04001491 mState.detachTransformFeedback(transformFeedback);
Geoff Langc8058452014-02-03 12:04:11 -05001492}
1493
Jamie Madilldc356042013-07-19 16:36:57 -04001494void Context::detachSampler(GLuint sampler)
1495{
Shannon Woods53a94a82014-06-24 15:20:36 -04001496 mState.detachSampler(sampler);
Jamie Madilldc356042013-07-19 16:36:57 -04001497}
1498
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001499void Context::setVertexAttribDivisor(GLuint index, GLuint divisor)
1500{
Jamie Madill0b9e9032015-08-17 11:51:52 +00001501 mState.setVertexAttribDivisor(index, divisor);
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001502}
1503
Jamie Madille29d1672013-07-19 16:36:57 -04001504void Context::samplerParameteri(GLuint sampler, GLenum pname, GLint param)
1505{
1506 mResourceManager->checkSamplerAllocation(sampler);
1507
1508 Sampler *samplerObject = getSampler(sampler);
1509 ASSERT(samplerObject);
1510
1511 switch (pname)
1512 {
1513 case GL_TEXTURE_MIN_FILTER: samplerObject->setMinFilter(static_cast<GLenum>(param)); break;
1514 case GL_TEXTURE_MAG_FILTER: samplerObject->setMagFilter(static_cast<GLenum>(param)); break;
1515 case GL_TEXTURE_WRAP_S: samplerObject->setWrapS(static_cast<GLenum>(param)); break;
1516 case GL_TEXTURE_WRAP_T: samplerObject->setWrapT(static_cast<GLenum>(param)); break;
1517 case GL_TEXTURE_WRAP_R: samplerObject->setWrapR(static_cast<GLenum>(param)); break;
1518 case GL_TEXTURE_MIN_LOD: samplerObject->setMinLod(static_cast<GLfloat>(param)); break;
1519 case GL_TEXTURE_MAX_LOD: samplerObject->setMaxLod(static_cast<GLfloat>(param)); break;
1520 case GL_TEXTURE_COMPARE_MODE: samplerObject->setComparisonMode(static_cast<GLenum>(param)); break;
1521 case GL_TEXTURE_COMPARE_FUNC: samplerObject->setComparisonFunc(static_cast<GLenum>(param)); break;
1522 default: UNREACHABLE(); break;
1523 }
1524}
1525
1526void Context::samplerParameterf(GLuint sampler, GLenum pname, GLfloat param)
1527{
1528 mResourceManager->checkSamplerAllocation(sampler);
1529
1530 Sampler *samplerObject = getSampler(sampler);
1531 ASSERT(samplerObject);
1532
1533 switch (pname)
1534 {
Jamie Madill9675b802013-07-19 16:36:59 -04001535 case GL_TEXTURE_MIN_FILTER: samplerObject->setMinFilter(uiround<GLenum>(param)); break;
1536 case GL_TEXTURE_MAG_FILTER: samplerObject->setMagFilter(uiround<GLenum>(param)); break;
1537 case GL_TEXTURE_WRAP_S: samplerObject->setWrapS(uiround<GLenum>(param)); break;
1538 case GL_TEXTURE_WRAP_T: samplerObject->setWrapT(uiround<GLenum>(param)); break;
1539 case GL_TEXTURE_WRAP_R: samplerObject->setWrapR(uiround<GLenum>(param)); break;
Shannon Woods53a94a82014-06-24 15:20:36 -04001540 case GL_TEXTURE_MIN_LOD: samplerObject->setMinLod(param); break;
1541 case GL_TEXTURE_MAX_LOD: samplerObject->setMaxLod(param); break;
Jamie Madill9675b802013-07-19 16:36:59 -04001542 case GL_TEXTURE_COMPARE_MODE: samplerObject->setComparisonMode(uiround<GLenum>(param)); break;
1543 case GL_TEXTURE_COMPARE_FUNC: samplerObject->setComparisonFunc(uiround<GLenum>(param)); break;
Jamie Madille29d1672013-07-19 16:36:57 -04001544 default: UNREACHABLE(); break;
1545 }
1546}
1547
Jamie Madill9675b802013-07-19 16:36:59 -04001548GLint Context::getSamplerParameteri(GLuint sampler, GLenum pname)
1549{
1550 mResourceManager->checkSamplerAllocation(sampler);
1551
1552 Sampler *samplerObject = getSampler(sampler);
1553 ASSERT(samplerObject);
1554
1555 switch (pname)
1556 {
1557 case GL_TEXTURE_MIN_FILTER: return static_cast<GLint>(samplerObject->getMinFilter());
1558 case GL_TEXTURE_MAG_FILTER: return static_cast<GLint>(samplerObject->getMagFilter());
1559 case GL_TEXTURE_WRAP_S: return static_cast<GLint>(samplerObject->getWrapS());
1560 case GL_TEXTURE_WRAP_T: return static_cast<GLint>(samplerObject->getWrapT());
1561 case GL_TEXTURE_WRAP_R: return static_cast<GLint>(samplerObject->getWrapR());
1562 case GL_TEXTURE_MIN_LOD: return uiround<GLint>(samplerObject->getMinLod());
1563 case GL_TEXTURE_MAX_LOD: return uiround<GLint>(samplerObject->getMaxLod());
1564 case GL_TEXTURE_COMPARE_MODE: return static_cast<GLint>(samplerObject->getComparisonMode());
1565 case GL_TEXTURE_COMPARE_FUNC: return static_cast<GLint>(samplerObject->getComparisonFunc());
1566 default: UNREACHABLE(); return 0;
1567 }
1568}
1569
1570GLfloat Context::getSamplerParameterf(GLuint sampler, GLenum pname)
1571{
1572 mResourceManager->checkSamplerAllocation(sampler);
1573
1574 Sampler *samplerObject = getSampler(sampler);
1575 ASSERT(samplerObject);
1576
1577 switch (pname)
1578 {
1579 case GL_TEXTURE_MIN_FILTER: return static_cast<GLfloat>(samplerObject->getMinFilter());
1580 case GL_TEXTURE_MAG_FILTER: return static_cast<GLfloat>(samplerObject->getMagFilter());
1581 case GL_TEXTURE_WRAP_S: return static_cast<GLfloat>(samplerObject->getWrapS());
1582 case GL_TEXTURE_WRAP_T: return static_cast<GLfloat>(samplerObject->getWrapT());
1583 case GL_TEXTURE_WRAP_R: return static_cast<GLfloat>(samplerObject->getWrapR());
1584 case GL_TEXTURE_MIN_LOD: return samplerObject->getMinLod();
1585 case GL_TEXTURE_MAX_LOD: return samplerObject->getMaxLod();
1586 case GL_TEXTURE_COMPARE_MODE: return static_cast<GLfloat>(samplerObject->getComparisonMode());
1587 case GL_TEXTURE_COMPARE_FUNC: return static_cast<GLfloat>(samplerObject->getComparisonFunc());
1588 default: UNREACHABLE(); return 0;
1589 }
1590}
1591
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001592void Context::initRendererString()
1593{
daniel@transgaming.comca1ac1f2013-01-11 04:13:05 +00001594 std::ostringstream rendererString;
1595 rendererString << "ANGLE (";
1596 rendererString << mRenderer->getRendererDescription();
1597 rendererString << ")";
1598
Geoff Langcec35902014-04-16 10:52:36 -04001599 mRendererString = MakeStaticString(rendererString.str());
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001600}
1601
Geoff Langc0b9ef42014-07-02 10:02:37 -04001602const std::string &Context::getRendererString() const
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001603{
daniel@transgaming.comca1ac1f2013-01-11 04:13:05 +00001604 return mRendererString;
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001605}
1606
Geoff Langcec35902014-04-16 10:52:36 -04001607void Context::initExtensionStrings()
1608{
Geoff Lang493daf52014-07-03 13:38:44 -04001609 mExtensionStrings = mExtensions.getStrings();
Geoff Langcec35902014-04-16 10:52:36 -04001610
Geoff Langc0b9ef42014-07-02 10:02:37 -04001611 std::ostringstream combinedStringStream;
1612 std::copy(mExtensionStrings.begin(), mExtensionStrings.end(), std::ostream_iterator<std::string>(combinedStringStream, " "));
1613 mExtensionString = combinedStringStream.str();
Geoff Langcec35902014-04-16 10:52:36 -04001614}
1615
Geoff Langc0b9ef42014-07-02 10:02:37 -04001616const std::string &Context::getExtensionString() const
Geoff Langcec35902014-04-16 10:52:36 -04001617{
1618 return mExtensionString;
1619}
1620
Geoff Langc0b9ef42014-07-02 10:02:37 -04001621const std::string &Context::getExtensionString(size_t idx) const
Geoff Langcec35902014-04-16 10:52:36 -04001622{
1623 return mExtensionStrings[idx];
1624}
1625
1626size_t Context::getExtensionStringCount() const
1627{
1628 return mExtensionStrings.size();
1629}
1630
Geoff Lang493daf52014-07-03 13:38:44 -04001631void Context::initCaps(GLuint clientVersion)
1632{
1633 mCaps = mRenderer->getRendererCaps();
1634
1635 mExtensions = mRenderer->getRendererExtensions();
1636
Austin Kinross02df7962015-07-01 10:03:42 -07001637 mLimitations = mRenderer->getRendererLimitations();
1638
Geoff Lang493daf52014-07-03 13:38:44 -04001639 if (clientVersion < 3)
1640 {
1641 // Disable ES3+ extensions
1642 mExtensions.colorBufferFloat = false;
1643 }
1644
1645 if (clientVersion > 2)
1646 {
1647 // FIXME(geofflang): Don't support EXT_sRGB in non-ES2 contexts
1648 //mExtensions.sRGB = false;
1649 }
1650
Geoff Lang301d1612014-07-09 10:34:37 -04001651 // Apply implementation limits
1652 mCaps.maxVertexAttributes = std::min<GLuint>(mCaps.maxVertexAttributes, MAX_VERTEX_ATTRIBS);
Geoff Lang301d1612014-07-09 10:34:37 -04001653 mCaps.maxVertexUniformBlocks = std::min<GLuint>(mCaps.maxVertexUniformBlocks, IMPLEMENTATION_MAX_VERTEX_SHADER_UNIFORM_BUFFERS);
1654 mCaps.maxVertexOutputComponents = std::min<GLuint>(mCaps.maxVertexOutputComponents, IMPLEMENTATION_MAX_VARYING_VECTORS * 4);
1655
1656 mCaps.maxFragmentInputComponents = std::min<GLuint>(mCaps.maxFragmentInputComponents, IMPLEMENTATION_MAX_VARYING_VECTORS * 4);
Geoff Lang3a61c322014-07-10 13:01:54 -04001657
Geoff Lang900013c2014-07-07 11:32:19 -04001658 mCaps.compressedTextureFormats.clear();
1659
Geoff Lang493daf52014-07-03 13:38:44 -04001660 const TextureCapsMap &rendererFormats = mRenderer->getRendererTextureCaps();
1661 for (TextureCapsMap::const_iterator i = rendererFormats.begin(); i != rendererFormats.end(); i++)
1662 {
1663 GLenum format = i->first;
1664 TextureCaps formatCaps = i->second;
1665
Geoff Lang5d601382014-07-22 15:14:06 -04001666 const InternalFormat &formatInfo = GetInternalFormatInfo(format);
Geoff Langd87878e2014-09-19 15:42:59 -04001667
1668 // Update the format caps based on the client version and extensions
1669 formatCaps.texturable = formatInfo.textureSupport(clientVersion, mExtensions);
1670 formatCaps.renderable = formatInfo.renderSupport(clientVersion, mExtensions);
1671 formatCaps.filterable = formatInfo.filterSupport(clientVersion, mExtensions);
1672
1673 // OpenGL ES does not support multisampling with integer formats
1674 if (!formatInfo.renderSupport || formatInfo.componentType == GL_INT || formatInfo.componentType == GL_UNSIGNED_INT)
Geoff Lang493daf52014-07-03 13:38:44 -04001675 {
Geoff Langd87878e2014-09-19 15:42:59 -04001676 formatCaps.sampleCounts.clear();
Geoff Lang493daf52014-07-03 13:38:44 -04001677 }
Geoff Langd87878e2014-09-19 15:42:59 -04001678
1679 if (formatCaps.texturable && formatInfo.compressed)
1680 {
1681 mCaps.compressedTextureFormats.push_back(format);
1682 }
1683
1684 mTextureCaps.insert(format, formatCaps);
Geoff Lang493daf52014-07-03 13:38:44 -04001685 }
1686}
1687
Jamie Madill1b94d432015-08-07 13:23:23 -04001688void Context::syncRendererState()
1689{
1690 const State::DirtyBits &dirtyBits = mState.getDirtyBits();
1691 if (dirtyBits.any())
1692 {
1693 mRenderer->syncState(mState, dirtyBits);
1694 mState.clearDirtyBits();
1695 }
1696}
1697
1698void Context::syncRendererState(const State::DirtyBits &bitMask)
1699{
1700 const State::DirtyBits &dirtyBits = (mState.getDirtyBits() & bitMask);
1701 if (dirtyBits.any())
1702 {
1703 mRenderer->syncState(mState, dirtyBits);
1704 mState.clearDirtyBits(dirtyBits);
1705 }
1706}
apatrick@chromium.org144f2802012-07-12 01:42:34 +00001707}