1 /*-------------------------------------------------------------------------
2 * drawElements Quality Program OpenGL ES Utilities
3 * ------------------------------------------------
4 *
5 * Copyright 2014 The Android Open Source Project
6 *
7 * Licensed under the Apache License, Version 2.0 (the "License");
8 * you may not use this file except in compliance with the License.
9 * You may obtain a copy of the License at
10 *
11 * http://www.apache.org/licenses/LICENSE-2.0
12 *
13 * Unless required by applicable law or agreed to in writing, software
14 * distributed under the License is distributed on an "AS IS" BASIS,
15 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 * See the License for the specific language governing permissions and
17 * limitations under the License.
18 *
19 *//*!
20 * \file
21 * \brief OpenGL State Reset.
22 *//*--------------------------------------------------------------------*/
23
24 #include "gluStateReset.hpp"
25 #include "gluContextInfo.hpp"
26 #include "gluRenderContext.hpp"
27 #include "tcuRenderTarget.hpp"
28 #include "glwFunctions.hpp"
29 #include "glwEnums.hpp"
30 #include "deUniquePtr.hpp"
31
32 namespace glu
33 {
34 namespace
35 {
36 enum
37 {
38 MAX_ERROR_COUNT = 10
39 };
40
resetErrors(const glw::Functions & gl)41 void resetErrors (const glw::Functions& gl)
42 {
43 size_t errorNdx = 0;
44
45 for (errorNdx = 0; errorNdx < MAX_ERROR_COUNT; errorNdx++)
46 {
47 if (gl.getError() == GL_NONE)
48 break;
49 }
50
51 if (errorNdx == MAX_ERROR_COUNT)
52 TCU_FAIL("Couldn't reset error state");
53 }
54
55 }
56
resetStateES(const RenderContext & renderCtx,const ContextInfo & ctxInfo)57 void resetStateES (const RenderContext& renderCtx, const ContextInfo& ctxInfo)
58 {
59 const glw::Functions& gl = renderCtx.getFunctions();
60 const ContextType type = renderCtx.getType();
61
62 // Reset error state
63 resetErrors(gl);
64
65 DE_ASSERT(isContextTypeES(type));
66
67 // Vertex attrib array state.
68 {
69 int numVertexAttribArrays = 0;
70 gl.getIntegerv(GL_MAX_VERTEX_ATTRIBS, &numVertexAttribArrays);
71
72 gl.bindBuffer (GL_ARRAY_BUFFER, 0);
73 gl.bindBuffer (GL_ELEMENT_ARRAY_BUFFER, 0);
74
75 if (contextSupports(type, ApiType::es(3,0)))
76 {
77 gl.bindVertexArray (0);
78 gl.disable (GL_PRIMITIVE_RESTART_FIXED_INDEX);
79 }
80
81 if (contextSupports(type, ApiType::es(3,1)))
82 gl.bindBuffer(GL_DRAW_INDIRECT_BUFFER, 0);
83
84 for (int ndx = 0; ndx < numVertexAttribArrays; ndx++)
85 {
86 gl.disableVertexAttribArray (ndx);
87 gl.vertexAttribPointer (ndx, 4, GL_FLOAT, GL_FALSE, 0, DE_NULL);
88
89 if (contextSupports(type, ApiType::es(3,0)))
90 gl.vertexAttribDivisor(ndx, 0);
91 }
92
93 GLU_EXPECT_NO_ERROR(gl.getError(), "Vertex attrib array state reset failed");
94 }
95
96 // Transformation state.
97 {
98 const tcu::RenderTarget& renderTarget = renderCtx.getRenderTarget();
99
100 gl.viewport (0, 0, renderTarget.getWidth(), renderTarget.getHeight());
101 gl.depthRangef (0.0f, 1.0f);
102
103 if (contextSupports(type, ApiType::es(3,0)))
104 gl.bindTransformFeedback(GL_TRANSFORM_FEEDBACK, 0);
105
106 GLU_EXPECT_NO_ERROR(gl.getError(), "Transformation state reset failed");
107 }
108
109 // Rasterization state
110 {
111 gl.lineWidth (1.0f);
112 gl.disable (GL_CULL_FACE);
113 gl.cullFace (GL_BACK);
114 gl.frontFace (GL_CCW);
115 gl.polygonOffset(0.0f, 0.0f);
116 gl.disable (GL_POLYGON_OFFSET_FILL);
117
118 if (contextSupports(type, ApiType::es(3,0)))
119 gl.disable(GL_RASTERIZER_DISCARD);
120
121 GLU_EXPECT_NO_ERROR(gl.getError(), "Rasterization state reset failed");
122 }
123
124 // Multisampling state
125 {
126 gl.disable (GL_SAMPLE_ALPHA_TO_COVERAGE);
127 gl.disable (GL_SAMPLE_COVERAGE);
128 gl.sampleCoverage (1.0f, GL_FALSE);
129
130 if (contextSupports(type, ApiType::es(3,1)))
131 {
132 int numSampleMaskWords = 0;
133 gl.getIntegerv(GL_MAX_SAMPLE_MASK_WORDS, &numSampleMaskWords);
134
135 gl.disable(GL_SAMPLE_MASK);
136
137 for (int ndx = 0; ndx < numSampleMaskWords; ndx++)
138 gl.sampleMaski(ndx, ~0u);
139 }
140
141 GLU_EXPECT_NO_ERROR(gl.getError(), "Multisampling state reset failed");
142 }
143
144 // Texture state.
145 // \todo [2013-04-08 pyry] Reset all levels?
146 {
147 const float borderColor[] = { 0.0f, 0.0f, 0.0f, 0.0f };
148 int numTexUnits = 0;
149 const bool supportsBorderClamp = ctxInfo.isExtensionSupported("GL_EXT_texture_border_clamp") || contextSupports(type, ApiType::es(3,2));
150
151 gl.getIntegerv(GL_MAX_COMBINED_TEXTURE_IMAGE_UNITS, &numTexUnits);
152
153 for (int ndx = 0; ndx < numTexUnits; ndx++)
154 {
155 gl.activeTexture(GL_TEXTURE0 + ndx);
156
157 // Reset 2D texture.
158 gl.bindTexture(GL_TEXTURE_2D, 0);
159 gl.texImage2D(GL_TEXTURE_2D, 0, GL_RGBA, 0, 0, 0, GL_RGBA, GL_UNSIGNED_BYTE, DE_NULL);
160 gl.texParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST_MIPMAP_LINEAR);
161 gl.texParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
162 gl.texParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_REPEAT);
163 gl.texParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_REPEAT);
164
165 if (contextSupports(type, ApiType::es(3,0)))
166 {
167 gl.texParameteri(GL_TEXTURE_2D, GL_TEXTURE_SWIZZLE_R, GL_RED);
168 gl.texParameteri(GL_TEXTURE_2D, GL_TEXTURE_SWIZZLE_G, GL_GREEN);
169 gl.texParameteri(GL_TEXTURE_2D, GL_TEXTURE_SWIZZLE_B, GL_BLUE);
170 gl.texParameteri(GL_TEXTURE_2D, GL_TEXTURE_SWIZZLE_A, GL_ALPHA);
171 gl.texParameterf(GL_TEXTURE_2D, GL_TEXTURE_MIN_LOD, -1000.0f);
172 gl.texParameterf(GL_TEXTURE_2D, GL_TEXTURE_MAX_LOD, 1000.0f);
173 gl.texParameteri(GL_TEXTURE_2D, GL_TEXTURE_BASE_LEVEL, 0);
174 gl.texParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAX_LEVEL, 1000);
175 gl.texParameteri(GL_TEXTURE_2D, GL_TEXTURE_COMPARE_MODE, GL_NONE);
176 gl.texParameteri(GL_TEXTURE_2D, GL_TEXTURE_COMPARE_FUNC, GL_LEQUAL);
177 }
178
179 if (contextSupports(type, ApiType::es(3,1)))
180 gl.texParameteri(GL_TEXTURE_2D, GL_DEPTH_STENCIL_TEXTURE_MODE, GL_DEPTH_COMPONENT);
181
182 if (supportsBorderClamp)
183 gl.texParameterfv(GL_TEXTURE_2D, GL_TEXTURE_BORDER_COLOR, &borderColor[0]);
184
185 // Reset cube map texture.
186 gl.bindTexture(GL_TEXTURE_CUBE_MAP, 0);
187 gl.texImage2D(GL_TEXTURE_CUBE_MAP_POSITIVE_X, 0, GL_RGBA, 0, 0, 0, GL_RGBA, GL_UNSIGNED_BYTE, DE_NULL);
188 gl.texImage2D(GL_TEXTURE_CUBE_MAP_NEGATIVE_X, 0, GL_RGBA, 0, 0, 0, GL_RGBA, GL_UNSIGNED_BYTE, DE_NULL);
189 gl.texImage2D(GL_TEXTURE_CUBE_MAP_POSITIVE_Y, 0, GL_RGBA, 0, 0, 0, GL_RGBA, GL_UNSIGNED_BYTE, DE_NULL);
190 gl.texImage2D(GL_TEXTURE_CUBE_MAP_NEGATIVE_Y, 0, GL_RGBA, 0, 0, 0, GL_RGBA, GL_UNSIGNED_BYTE, DE_NULL);
191 gl.texImage2D(GL_TEXTURE_CUBE_MAP_POSITIVE_Z, 0, GL_RGBA, 0, 0, 0, GL_RGBA, GL_UNSIGNED_BYTE, DE_NULL);
192 gl.texImage2D(GL_TEXTURE_CUBE_MAP_NEGATIVE_Z, 0, GL_RGBA, 0, 0, 0, GL_RGBA, GL_UNSIGNED_BYTE, DE_NULL);
193 gl.texParameteri(GL_TEXTURE_CUBE_MAP, GL_TEXTURE_MIN_FILTER, GL_NEAREST_MIPMAP_LINEAR);
194 gl.texParameteri(GL_TEXTURE_CUBE_MAP, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
195 gl.texParameteri(GL_TEXTURE_CUBE_MAP, GL_TEXTURE_WRAP_S, GL_REPEAT);
196 gl.texParameteri(GL_TEXTURE_CUBE_MAP, GL_TEXTURE_WRAP_T, GL_REPEAT);
197
198 if (contextSupports(type, ApiType::es(3,0)))
199 {
200 gl.texParameteri(GL_TEXTURE_CUBE_MAP, GL_TEXTURE_SWIZZLE_R, GL_RED);
201 gl.texParameteri(GL_TEXTURE_CUBE_MAP, GL_TEXTURE_SWIZZLE_G, GL_GREEN);
202 gl.texParameteri(GL_TEXTURE_CUBE_MAP, GL_TEXTURE_SWIZZLE_B, GL_BLUE);
203 gl.texParameteri(GL_TEXTURE_CUBE_MAP, GL_TEXTURE_SWIZZLE_A, GL_ALPHA);
204 gl.texParameterf(GL_TEXTURE_CUBE_MAP, GL_TEXTURE_MIN_LOD, -1000.0f);
205 gl.texParameterf(GL_TEXTURE_CUBE_MAP, GL_TEXTURE_MAX_LOD, 1000.0f);
206 gl.texParameteri(GL_TEXTURE_CUBE_MAP, GL_TEXTURE_BASE_LEVEL, 0);
207 gl.texParameteri(GL_TEXTURE_CUBE_MAP, GL_TEXTURE_MAX_LEVEL, 1000);
208 gl.texParameteri(GL_TEXTURE_CUBE_MAP, GL_TEXTURE_COMPARE_MODE, GL_NONE);
209 gl.texParameteri(GL_TEXTURE_CUBE_MAP, GL_TEXTURE_COMPARE_FUNC, GL_LEQUAL);
210 }
211
212 if (contextSupports(type, ApiType::es(3,1)))
213 gl.texParameteri(GL_TEXTURE_CUBE_MAP, GL_DEPTH_STENCIL_TEXTURE_MODE, GL_DEPTH_COMPONENT);
214
215 if (supportsBorderClamp)
216 gl.texParameterfv(GL_TEXTURE_CUBE_MAP, GL_TEXTURE_BORDER_COLOR, &borderColor[0]);
217
218 if (contextSupports(type, ApiType::es(3,0)))
219 {
220 // Reset 2D array texture.
221 gl.bindTexture(GL_TEXTURE_2D_ARRAY, 0);
222 gl.texImage3D(GL_TEXTURE_2D_ARRAY, 0, GL_RGBA, 0, 0, 0, 0, GL_RGBA, GL_UNSIGNED_BYTE, DE_NULL);
223 gl.texParameteri(GL_TEXTURE_2D_ARRAY, GL_TEXTURE_MIN_FILTER, GL_NEAREST_MIPMAP_LINEAR);
224 gl.texParameteri(GL_TEXTURE_2D_ARRAY, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
225 gl.texParameteri(GL_TEXTURE_2D_ARRAY, GL_TEXTURE_WRAP_S, GL_REPEAT);
226 gl.texParameteri(GL_TEXTURE_2D_ARRAY, GL_TEXTURE_WRAP_T, GL_REPEAT);
227 gl.texParameteri(GL_TEXTURE_2D_ARRAY, GL_TEXTURE_SWIZZLE_R, GL_RED);
228 gl.texParameteri(GL_TEXTURE_2D_ARRAY, GL_TEXTURE_SWIZZLE_G, GL_GREEN);
229 gl.texParameteri(GL_TEXTURE_2D_ARRAY, GL_TEXTURE_SWIZZLE_B, GL_BLUE);
230 gl.texParameteri(GL_TEXTURE_2D_ARRAY, GL_TEXTURE_SWIZZLE_A, GL_ALPHA);
231 gl.texParameterf(GL_TEXTURE_2D_ARRAY, GL_TEXTURE_MIN_LOD, -1000.0f);
232 gl.texParameterf(GL_TEXTURE_2D_ARRAY, GL_TEXTURE_MAX_LOD, 1000.0f);
233 gl.texParameteri(GL_TEXTURE_2D_ARRAY, GL_TEXTURE_BASE_LEVEL, 0);
234 gl.texParameteri(GL_TEXTURE_2D_ARRAY, GL_TEXTURE_MAX_LEVEL, 1000);
235 gl.texParameteri(GL_TEXTURE_2D_ARRAY, GL_TEXTURE_COMPARE_MODE, GL_NONE);
236 gl.texParameteri(GL_TEXTURE_2D_ARRAY, GL_TEXTURE_COMPARE_FUNC, GL_LEQUAL);
237
238 if (supportsBorderClamp)
239 gl.texParameterfv(GL_TEXTURE_2D_ARRAY, GL_TEXTURE_BORDER_COLOR, &borderColor[0]);
240 }
241
242 if (contextSupports(type, ApiType::es(3,1)))
243 gl.texParameteri(GL_TEXTURE_2D_ARRAY, GL_DEPTH_STENCIL_TEXTURE_MODE, GL_DEPTH_COMPONENT);
244
245 if (contextSupports(type, ApiType::es(3,0)))
246 {
247 // Reset 3D texture.
248 gl.bindTexture(GL_TEXTURE_3D, 0);
249 gl.texImage3D(GL_TEXTURE_3D, 0, GL_RGBA, 0, 0, 0, 0, GL_RGBA, GL_UNSIGNED_BYTE, DE_NULL);
250 gl.texParameteri(GL_TEXTURE_3D, GL_TEXTURE_MIN_FILTER, GL_NEAREST_MIPMAP_LINEAR);
251 gl.texParameteri(GL_TEXTURE_3D, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
252 gl.texParameteri(GL_TEXTURE_3D, GL_TEXTURE_WRAP_S, GL_REPEAT);
253 gl.texParameteri(GL_TEXTURE_3D, GL_TEXTURE_WRAP_T, GL_REPEAT);
254 gl.texParameteri(GL_TEXTURE_3D, GL_TEXTURE_WRAP_R, GL_REPEAT);
255 gl.texParameteri(GL_TEXTURE_3D, GL_TEXTURE_SWIZZLE_R, GL_RED);
256 gl.texParameteri(GL_TEXTURE_3D, GL_TEXTURE_SWIZZLE_G, GL_GREEN);
257 gl.texParameteri(GL_TEXTURE_3D, GL_TEXTURE_SWIZZLE_B, GL_BLUE);
258 gl.texParameteri(GL_TEXTURE_3D, GL_TEXTURE_SWIZZLE_A, GL_ALPHA);
259 gl.texParameterf(GL_TEXTURE_3D, GL_TEXTURE_MIN_LOD, -1000.0f);
260 gl.texParameterf(GL_TEXTURE_3D, GL_TEXTURE_MAX_LOD, 1000.0f);
261 gl.texParameteri(GL_TEXTURE_3D, GL_TEXTURE_BASE_LEVEL, 0);
262 gl.texParameteri(GL_TEXTURE_3D, GL_TEXTURE_MAX_LEVEL, 1000);
263 gl.texParameteri(GL_TEXTURE_3D, GL_TEXTURE_COMPARE_MODE, GL_NONE);
264 gl.texParameteri(GL_TEXTURE_3D, GL_TEXTURE_COMPARE_FUNC, GL_LEQUAL);
265
266 if (supportsBorderClamp)
267 gl.texParameterfv(GL_TEXTURE_3D, GL_TEXTURE_BORDER_COLOR, &borderColor[0]);
268 }
269
270 if (contextSupports(type, ApiType::es(3,1)))
271 gl.texParameteri(GL_TEXTURE_3D, GL_DEPTH_STENCIL_TEXTURE_MODE, GL_DEPTH_COMPONENT);
272
273 if (contextSupports(type, ApiType::es(3,1)))
274 {
275 // Reset multisample textures.
276 gl.bindTexture(GL_TEXTURE_2D_MULTISAMPLE, 0);
277 gl.texParameteri(GL_TEXTURE_2D_MULTISAMPLE, GL_TEXTURE_SWIZZLE_R, GL_RED);
278 gl.texParameteri(GL_TEXTURE_2D_MULTISAMPLE, GL_TEXTURE_SWIZZLE_G, GL_GREEN);
279 gl.texParameteri(GL_TEXTURE_2D_MULTISAMPLE, GL_TEXTURE_SWIZZLE_B, GL_BLUE);
280 gl.texParameteri(GL_TEXTURE_2D_MULTISAMPLE, GL_TEXTURE_SWIZZLE_A, GL_ALPHA);
281 gl.texParameteri(GL_TEXTURE_2D_MULTISAMPLE, GL_TEXTURE_BASE_LEVEL, 0);
282 gl.texParameteri(GL_TEXTURE_2D_MULTISAMPLE, GL_TEXTURE_MAX_LEVEL, 1000);
283 }
284
285 if (ctxInfo.isExtensionSupported("GL_OES_texture_storage_multisample_2d_array"))
286 {
287 gl.bindTexture(GL_TEXTURE_2D_MULTISAMPLE_ARRAY, 0);
288 gl.texParameteri(GL_TEXTURE_2D_MULTISAMPLE_ARRAY, GL_TEXTURE_SWIZZLE_R, GL_RED);
289 gl.texParameteri(GL_TEXTURE_2D_MULTISAMPLE_ARRAY, GL_TEXTURE_SWIZZLE_G, GL_GREEN);
290 gl.texParameteri(GL_TEXTURE_2D_MULTISAMPLE_ARRAY, GL_TEXTURE_SWIZZLE_B, GL_BLUE);
291 gl.texParameteri(GL_TEXTURE_2D_MULTISAMPLE_ARRAY, GL_TEXTURE_SWIZZLE_A, GL_ALPHA);
292 gl.texParameteri(GL_TEXTURE_2D_MULTISAMPLE_ARRAY, GL_TEXTURE_BASE_LEVEL, 0);
293 gl.texParameteri(GL_TEXTURE_2D_MULTISAMPLE_ARRAY, GL_TEXTURE_MAX_LEVEL, 1000);
294 }
295
296 if (ctxInfo.isExtensionSupported("GL_EXT_texture_cube_map_array"))
297 {
298 // Reset cube array texture.
299 gl.bindTexture(GL_TEXTURE_CUBE_MAP_ARRAY, 0);
300 gl.texParameteri(GL_TEXTURE_CUBE_MAP_ARRAY, GL_TEXTURE_MIN_FILTER, GL_NEAREST_MIPMAP_LINEAR);
301 gl.texParameteri(GL_TEXTURE_CUBE_MAP_ARRAY, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
302 gl.texParameteri(GL_TEXTURE_CUBE_MAP_ARRAY, GL_TEXTURE_WRAP_S, GL_REPEAT);
303 gl.texParameteri(GL_TEXTURE_CUBE_MAP_ARRAY, GL_TEXTURE_WRAP_T, GL_REPEAT);
304 gl.texParameteri(GL_TEXTURE_CUBE_MAP_ARRAY, GL_TEXTURE_SWIZZLE_R, GL_RED);
305 gl.texParameteri(GL_TEXTURE_CUBE_MAP_ARRAY, GL_TEXTURE_SWIZZLE_G, GL_GREEN);
306 gl.texParameteri(GL_TEXTURE_CUBE_MAP_ARRAY, GL_TEXTURE_SWIZZLE_B, GL_BLUE);
307 gl.texParameteri(GL_TEXTURE_CUBE_MAP_ARRAY, GL_TEXTURE_SWIZZLE_A, GL_ALPHA);
308 gl.texParameterf(GL_TEXTURE_CUBE_MAP_ARRAY, GL_TEXTURE_MIN_LOD, -1000.0f);
309 gl.texParameterf(GL_TEXTURE_CUBE_MAP_ARRAY, GL_TEXTURE_MAX_LOD, 1000.0f);
310 gl.texParameteri(GL_TEXTURE_CUBE_MAP_ARRAY, GL_TEXTURE_BASE_LEVEL, 0);
311 gl.texParameteri(GL_TEXTURE_CUBE_MAP_ARRAY, GL_TEXTURE_MAX_LEVEL, 1000);
312 gl.texParameteri(GL_TEXTURE_CUBE_MAP_ARRAY, GL_TEXTURE_COMPARE_MODE, GL_NONE);
313 gl.texParameteri(GL_TEXTURE_CUBE_MAP_ARRAY, GL_TEXTURE_COMPARE_FUNC, GL_LEQUAL);
314
315 if (supportsBorderClamp)
316 gl.texParameterfv(GL_TEXTURE_CUBE_MAP_ARRAY, GL_TEXTURE_BORDER_COLOR, &borderColor[0]);
317 }
318 }
319
320 gl.activeTexture(GL_TEXTURE0);
321
322 if (contextSupports(type, ApiType::es(3,0)))
323 {
324 for (int ndx = 0; ndx < numTexUnits; ndx++)
325 gl.bindSampler(ndx, 0);
326 }
327
328 GLU_EXPECT_NO_ERROR(gl.getError(), "Texture state reset failed");
329 }
330
331 // Resetting state using non-indexed variants should be enough, but some
332 // implementations have bugs so we need to make sure indexed state gets
333 // set back to initial values.
334 if (ctxInfo.isExtensionSupported("GL_EXT_draw_buffers_indexed"))
335 {
336 int numDrawBuffers = 0;
337
338 gl.getIntegerv(GL_MAX_DRAW_BUFFERS, &numDrawBuffers);
339
340 for (int drawBufferNdx = 0; drawBufferNdx < numDrawBuffers; drawBufferNdx++)
341 {
342 gl.disablei (GL_BLEND, drawBufferNdx);
343 gl.blendFunci (drawBufferNdx, GL_ONE, GL_ZERO);
344 gl.blendEquationi (drawBufferNdx, GL_FUNC_ADD);
345 gl.colorMaski (drawBufferNdx, GL_TRUE, GL_TRUE, GL_TRUE, GL_TRUE);
346 }
347
348 GLU_EXPECT_NO_ERROR(gl.getError(), "Failed to reset indexed draw buffer state");
349 }
350
351 // Pixel operations.
352 {
353 const tcu::RenderTarget& renderTarget = renderCtx.getRenderTarget();
354
355 gl.disable (GL_SCISSOR_TEST);
356 gl.scissor (0, 0, renderTarget.getWidth(), renderTarget.getHeight());
357
358 gl.disable (GL_STENCIL_TEST);
359 gl.stencilFunc (GL_ALWAYS, 0, ~0u);
360 gl.stencilOp (GL_KEEP, GL_KEEP, GL_KEEP);
361
362 gl.disable (GL_DEPTH_TEST);
363 gl.depthFunc (GL_LESS);
364
365 gl.disable (GL_BLEND);
366 gl.blendFunc (GL_ONE, GL_ZERO);
367 gl.blendEquation(GL_FUNC_ADD);
368 gl.blendColor (0.0f, 0.0f, 0.0f, 0.0f);
369
370 gl.enable (GL_DITHER);
371
372 if (ctxInfo.isExtensionSupported("GL_EXT_sRGB_write_control"))
373 {
374 gl.enable (GL_FRAMEBUFFER_SRGB);
375 }
376
377 GLU_EXPECT_NO_ERROR(gl.getError(), "Pixel operation state reset failed");
378 }
379
380 // Framebuffer control.
381 {
382 gl.colorMask (GL_TRUE, GL_TRUE, GL_TRUE, GL_TRUE);
383 gl.depthMask (GL_TRUE);
384 gl.stencilMask (~0u);
385
386 gl.clearColor (0.0f, 0.0f, 0.0f, 0.0f);
387 gl.clearDepthf (1.0f);
388 gl.clearStencil (0);
389
390 GLU_EXPECT_NO_ERROR(gl.getError(), "Framebuffer control state reset failed");
391 }
392
393 // Framebuffer state.
394 {
395 // \note Actually spec explictly says 0 but on some platforms (iOS) no default framebuffer exists.
396 const deUint32 defaultFbo = renderCtx.getDefaultFramebuffer();
397 const deUint32 drawBuffer = defaultFbo != 0 ? GL_COLOR_ATTACHMENT0 : GL_BACK;
398 const deUint32 readBuffer = defaultFbo != 0 ? GL_COLOR_ATTACHMENT0 : GL_BACK;
399
400 gl.bindFramebuffer(GL_FRAMEBUFFER, defaultFbo);
401
402 if (contextSupports(type, ApiType::es(3,0)))
403 {
404 gl.drawBuffers (1, &drawBuffer);
405 gl.readBuffer (readBuffer);
406 }
407
408 if (contextSupports(type, ApiType::es(3, 1)) && defaultFbo != 0)
409 {
410 gl.framebufferParameteri(GL_FRAMEBUFFER, GL_FRAMEBUFFER_DEFAULT_WIDTH, 0);
411 gl.framebufferParameteri(GL_FRAMEBUFFER, GL_FRAMEBUFFER_DEFAULT_HEIGHT, 0);
412 gl.framebufferParameteri(GL_FRAMEBUFFER, GL_FRAMEBUFFER_DEFAULT_SAMPLES, 0);
413 gl.framebufferParameteri(GL_FRAMEBUFFER, GL_FRAMEBUFFER_DEFAULT_FIXED_SAMPLE_LOCATIONS, GL_FALSE);
414 GLU_EXPECT_NO_ERROR(gl.getError(), "Framebuffer default state reset failed");
415 }
416
417 GLU_EXPECT_NO_ERROR(gl.getError(), "Framebuffer state reset failed");
418 }
419
420 // Renderbuffer state.
421 {
422 gl.bindRenderbuffer(GL_RENDERBUFFER, 0);
423 GLU_EXPECT_NO_ERROR(gl.getError(), "Renderbuffer state reset failed");
424 }
425
426 // Pixel transfer state.
427 {
428 gl.pixelStorei(GL_UNPACK_ALIGNMENT, 4);
429 gl.pixelStorei(GL_PACK_ALIGNMENT, 4);
430
431 if (contextSupports(type, ApiType::es(3,0)))
432 {
433 gl.pixelStorei(GL_UNPACK_IMAGE_HEIGHT, 0);
434 gl.pixelStorei(GL_UNPACK_SKIP_IMAGES, 0);
435 gl.pixelStorei(GL_UNPACK_ROW_LENGTH, 0);
436 gl.pixelStorei(GL_UNPACK_SKIP_ROWS, 0);
437 gl.pixelStorei(GL_UNPACK_SKIP_PIXELS, 0);
438
439 gl.pixelStorei(GL_PACK_ROW_LENGTH, 0);
440 gl.pixelStorei(GL_PACK_SKIP_ROWS, 0);
441 gl.pixelStorei(GL_PACK_SKIP_PIXELS, 0);
442
443 gl.bindBuffer(GL_PIXEL_PACK_BUFFER, 0);
444 gl.bindBuffer(GL_PIXEL_UNPACK_BUFFER, 0);
445 }
446
447 GLU_EXPECT_NO_ERROR(gl.getError(), "Pixel transfer state reset failed");
448 }
449
450 // Program object state.
451 {
452 gl.useProgram(0);
453
454 if (contextSupports(type, ApiType::es(3,0)))
455 {
456 int maxUniformBufferBindings = 0;
457 gl.getIntegerv (GL_MAX_UNIFORM_BUFFER_BINDINGS, &maxUniformBufferBindings);
458 gl.bindBuffer (GL_UNIFORM_BUFFER, 0);
459
460 for (int ndx = 0; ndx < maxUniformBufferBindings; ndx++)
461 gl.bindBufferBase(GL_UNIFORM_BUFFER, ndx, 0);
462 }
463
464 if (contextSupports(type, ApiType::es(3,1)))
465 {
466 gl.bindProgramPipeline(0);
467
468 {
469 int maxAtomicCounterBufferBindings = 0;
470 gl.getIntegerv (GL_MAX_ATOMIC_COUNTER_BUFFER_BINDINGS, &maxAtomicCounterBufferBindings);
471 gl.bindBuffer (GL_ATOMIC_COUNTER_BUFFER, 0);
472
473 for (int ndx = 0; ndx < maxAtomicCounterBufferBindings; ndx++)
474 gl.bindBufferBase(GL_ATOMIC_COUNTER_BUFFER, ndx, 0);
475 }
476
477 {
478 int maxShaderStorageBufferBindings = 0;
479 gl.getIntegerv (GL_MAX_SHADER_STORAGE_BUFFER_BINDINGS, &maxShaderStorageBufferBindings);
480 gl.bindBuffer (GL_SHADER_STORAGE_BUFFER, 0);
481
482 for (int ndx = 0; ndx < maxShaderStorageBufferBindings; ndx++)
483 gl.bindBufferBase(GL_SHADER_STORAGE_BUFFER, ndx, 0);
484 }
485 }
486
487 GLU_EXPECT_NO_ERROR(gl.getError(), "Program object state reset failed");
488 }
489
490 // Vertex shader state.
491 {
492 int numVertexAttribArrays = 0;
493 gl.getIntegerv(GL_MAX_VERTEX_ATTRIBS, &numVertexAttribArrays);
494
495 for (int ndx = 0; ndx < numVertexAttribArrays; ndx++)
496 gl.vertexAttrib4f(ndx, 0.0f, 0.0f, 0.0f, 1.0f);
497
498 GLU_EXPECT_NO_ERROR(gl.getError(), "Vertex shader state reset failed");
499 }
500
501 // Transform feedback state.
502 if (contextSupports(type, ApiType::es(3,0)))
503 {
504 int numTransformFeedbackSeparateAttribs = 0;
505 glw::GLboolean transformFeedbackActive = 0;
506 gl.getIntegerv(GL_MAX_TRANSFORM_FEEDBACK_SEPARATE_ATTRIBS, &numTransformFeedbackSeparateAttribs);
507 gl.getBooleanv(GL_TRANSFORM_FEEDBACK_ACTIVE, &transformFeedbackActive);
508
509 if (transformFeedbackActive)
510 gl.endTransformFeedback();
511
512 gl.bindBuffer(GL_TRANSFORM_FEEDBACK_BUFFER, 0);
513
514 for (int ndx = 0; ndx < numTransformFeedbackSeparateAttribs; ndx++)
515 gl.bindBufferBase(GL_TRANSFORM_FEEDBACK_BUFFER, ndx, 0);
516
517 GLU_EXPECT_NO_ERROR(gl.getError(), "Transform feedback state reset failed");
518 }
519
520 // Asynchronous query state.
521 if (contextSupports(type, ApiType::es(3,0)))
522 {
523 static const deUint32 targets[] = { GL_ANY_SAMPLES_PASSED, GL_ANY_SAMPLES_PASSED_CONSERVATIVE, GL_TRANSFORM_FEEDBACK_PRIMITIVES_WRITTEN };
524
525 for (int i = 0; i < DE_LENGTH_OF_ARRAY(targets); i++)
526 {
527 int queryActive = 0;
528 gl.getQueryiv(targets[i], GL_CURRENT_QUERY, &queryActive);
529
530 if (queryActive != 0)
531 gl.endQuery(targets[i]);
532 }
533
534 GLU_EXPECT_NO_ERROR(gl.getError(), "Asynchronous query state reset failed");
535 }
536
537 // Hints.
538 {
539 gl.hint(GL_GENERATE_MIPMAP_HINT, GL_DONT_CARE);
540
541 if (contextSupports(type, ApiType::es(3,0)))
542 gl.hint(GL_FRAGMENT_SHADER_DERIVATIVE_HINT, GL_DONT_CARE);
543
544 GLU_EXPECT_NO_ERROR(gl.getError(), "Hints reset failed");
545 }
546
547 // Compute.
548 if (contextSupports(type, ApiType::es(3,1)))
549 {
550 gl.bindBuffer(GL_DISPATCH_INDIRECT_BUFFER, 0);
551 GLU_EXPECT_NO_ERROR(gl.getError(), "Compute dispatch state reset failed");
552 }
553
554 // Buffer copy state.
555 if (contextSupports(type, ApiType::es(3,0)))
556 {
557 gl.bindBuffer(GL_COPY_READ_BUFFER, 0);
558 gl.bindBuffer(GL_COPY_WRITE_BUFFER, 0);
559
560 GLU_EXPECT_NO_ERROR(gl.getError(), "Buffer copy state reset failed");
561 }
562
563 // Images.
564 if (contextSupports(type, ApiType::es(3,1)))
565 {
566 int numImageUnits = 0;
567 gl.getIntegerv(GL_MAX_IMAGE_UNITS, &numImageUnits);
568
569 for (int ndx = 0; ndx < numImageUnits; ndx++)
570 gl.bindImageTexture(ndx, 0, 0, GL_FALSE, 0, GL_READ_ONLY, GL_R32UI);
571
572 GLU_EXPECT_NO_ERROR(gl.getError(), "Image state reset failed");
573 }
574
575 // Sample shading state.
576 if (contextSupports(type, ApiType::es(3,1)) && ctxInfo.isExtensionSupported("GL_OES_sample_shading"))
577 {
578 gl.minSampleShading(0.0f);
579 gl.disable(GL_SAMPLE_SHADING);
580
581 GLU_EXPECT_NO_ERROR(gl.getError(), "Sample shading state reset failed");
582 }
583
584 // Debug state
585 if (ctxInfo.isExtensionSupported("GL_KHR_debug"))
586 {
587 const bool entrypointsPresent = gl.debugMessageControl != DE_NULL &&
588 gl.debugMessageCallback != DE_NULL &&
589 gl.popDebugGroup != DE_NULL;
590
591 // some drivers advertise GL_KHR_debug but give out null pointers. Silently ignore.
592 if (entrypointsPresent)
593 {
594 int stackDepth = 0;
595 gl.getIntegerv(GL_DEBUG_GROUP_STACK_DEPTH, &stackDepth);
596 for (int ndx = 1; ndx < stackDepth; ++ndx)
597 gl.popDebugGroup();
598
599 gl.debugMessageControl(GL_DONT_CARE, GL_DONT_CARE, GL_DONT_CARE, 0, DE_NULL, true);
600 gl.debugMessageControl(GL_DONT_CARE, GL_DONT_CARE, GL_DEBUG_SEVERITY_LOW, 0, DE_NULL, false);
601 gl.debugMessageCallback(DE_NULL, DE_NULL);
602
603 if (type.getFlags() & glu::CONTEXT_DEBUG)
604 gl.enable(GL_DEBUG_OUTPUT);
605 else
606 gl.disable(GL_DEBUG_OUTPUT);
607 gl.disable(GL_DEBUG_OUTPUT_SYNCHRONOUS);
608
609 GLU_EXPECT_NO_ERROR(gl.getError(), "Debug state reset failed");
610 }
611 }
612
613 // Primitive bounding box state.
614 if (ctxInfo.isExtensionSupported("GL_EXT_primitive_bounding_box"))
615 {
616 gl.primitiveBoundingBox(-1.0f, -1.0f, -1.0f, 1.0f, 1.0f, 1.0f, 1.0f, 1.0f);
617 GLU_EXPECT_NO_ERROR(gl.getError(), "Primitive bounding box state reset failed");
618 }
619
620 // Tessellation state
621 if (ctxInfo.isExtensionSupported("GL_EXT_tessellation_shader"))
622 {
623 gl.patchParameteri(GL_PATCH_VERTICES, 3);
624 GLU_EXPECT_NO_ERROR(gl.getError(), "Tessellation patch vertices state reset failed");
625 }
626
627 // Advanced coherent blending
628 if (ctxInfo.isExtensionSupported("GL_KHR_blend_equation_advanced_coherent"))
629 {
630 gl.enable(GL_BLEND_ADVANCED_COHERENT_KHR);
631 GLU_EXPECT_NO_ERROR(gl.getError(), "Blend equation advanced coherent state reset failed");
632 }
633
634 // Texture buffer
635 if (ctxInfo.isExtensionSupported("GL_EXT_texture_buffer"))
636 {
637 gl.bindTexture(GL_TEXTURE_BUFFER, 0);
638 gl.bindBuffer(GL_TEXTURE_BUFFER, 0);
639 GLU_EXPECT_NO_ERROR(gl.getError(), "Texture buffer state reset failed");
640 }
641 }
642
resetStateGLCore(const RenderContext & renderCtx,const ContextInfo & ctxInfo)643 void resetStateGLCore (const RenderContext& renderCtx, const ContextInfo& ctxInfo)
644 {
645 const glw::Functions& gl = renderCtx.getFunctions();
646 const ContextType type = renderCtx.getType();
647
648 // Reset error state
649 resetErrors(gl);
650
651 // Primitives and vertices state
652 {
653 if (contextSupports(type, glu::ApiType::core(4, 0)))
654 {
655 const float defaultTessLevels[] = { 1.0f, 1.0f, 1.0f, 1.0f };
656 gl.patchParameteri(GL_PATCH_VERTICES_EXT, 3);
657 gl.patchParameterfv(GL_PATCH_DEFAULT_INNER_LEVEL, defaultTessLevels);
658 gl.patchParameterfv(GL_PATCH_DEFAULT_OUTER_LEVEL, defaultTessLevels);
659 }
660
661 GLU_EXPECT_NO_ERROR(gl.getError(), "Primitives and vertices state reset failed");
662 }
663
664 // Vertex attrib array state.
665 {
666 gl.bindVertexArray (0);
667 gl.bindBuffer (GL_ARRAY_BUFFER, 0);
668 gl.bindBuffer (GL_ELEMENT_ARRAY_BUFFER, 0);
669
670 if (contextSupports(type, ApiType::core(3,1)))
671 {
672 gl.disable (GL_PRIMITIVE_RESTART);
673 gl.primitiveRestartIndex(0);
674 }
675
676 GLU_EXPECT_NO_ERROR(gl.getError(), "Vertex attrib array state reset failed");
677 }
678
679 // Transformation state.
680 {
681 const tcu::RenderTarget& renderTarget = renderCtx.getRenderTarget();
682 int numUserClipPlanes = 0;
683
684 gl.getIntegerv(GL_MAX_CLIP_DISTANCES, &numUserClipPlanes);
685
686 gl.viewport (0, 0, renderTarget.getWidth(), renderTarget.getHeight());
687 gl.depthRange (0.0, 1.0);
688
689 for (int ndx = 0; ndx < numUserClipPlanes; ndx++)
690 gl.disable(GL_CLIP_DISTANCE0+ndx);
691
692 if (contextSupports(type, ApiType::core(3,2)))
693 gl.disable(GL_DEPTH_CLAMP);
694
695 //gl.bindTransformFeedback(GL_TRANSFORM_FEEDBACK, 0);
696
697 GLU_EXPECT_NO_ERROR(gl.getError(), "Transformation state reset failed");
698 }
699
700 // Coloring
701 {
702 gl.clampColor(GL_CLAMP_READ_COLOR, GL_FIXED_ONLY);
703
704 if (contextSupports(type, ApiType::core(3,2)))
705 gl.provokingVertex(GL_LAST_VERTEX_CONVENTION);
706
707 GLU_EXPECT_NO_ERROR(gl.getError(), "Coloring state reset failed");
708 }
709
710 // Rasterization state
711 {
712 gl.disable (GL_RASTERIZER_DISCARD);
713 gl.pointSize (1.0f);
714 gl.pointParameterf (GL_POINT_FADE_THRESHOLD_SIZE, 1.0f);
715 gl.pointParameteri (GL_POINT_SPRITE_COORD_ORIGIN, GL_UPPER_LEFT);
716 gl.lineWidth (1.0f);
717 gl.disable (GL_LINE_SMOOTH);
718 gl.disable (GL_CULL_FACE);
719 gl.cullFace (GL_BACK);
720 gl.frontFace (GL_CCW);
721 gl.disable (GL_POLYGON_SMOOTH);
722 gl.polygonOffset (0.0f, 0.0f);
723 gl.disable (GL_POLYGON_OFFSET_POINT);
724 gl.disable (GL_POLYGON_OFFSET_LINE);
725 gl.disable (GL_POLYGON_OFFSET_FILL);
726
727 GLU_EXPECT_NO_ERROR(gl.getError(), "Rasterization state reset failed");
728 }
729
730 // Multisampling state
731 {
732 gl.enable (GL_MULTISAMPLE);
733 gl.disable (GL_SAMPLE_ALPHA_TO_COVERAGE);
734 gl.disable (GL_SAMPLE_ALPHA_TO_ONE);
735 gl.disable (GL_SAMPLE_COVERAGE);
736 gl.sampleCoverage (1.0f, GL_FALSE);
737
738 if (contextSupports(type, ApiType::core(3,2)))
739 {
740 int numSampleMaskWords = 0;
741 gl.getIntegerv(GL_MAX_SAMPLE_MASK_WORDS, &numSampleMaskWords);
742
743 gl.disable(GL_SAMPLE_MASK);
744
745 for (int ndx = 0; ndx < numSampleMaskWords; ndx++)
746 gl.sampleMaski(ndx, ~0u);
747 }
748
749 GLU_EXPECT_NO_ERROR(gl.getError(), "Multisampling state reset failed");
750 }
751
752 // Texture state.
753 // \todo [2013-04-08 pyry] Reset all levels?
754 {
755 const float borderColor[] = { 0.0f, 0.0f, 0.0f, 0.0f };
756 int numTexUnits = 0;
757 gl.getIntegerv(GL_MAX_COMBINED_TEXTURE_IMAGE_UNITS, &numTexUnits);
758
759 gl.bindBuffer(GL_TEXTURE_BUFFER, 0);
760
761 for (int ndx = 0; ndx < numTexUnits; ndx++)
762 {
763 gl.activeTexture(GL_TEXTURE0 + ndx);
764
765 // Reset 1D texture.
766 gl.bindTexture (GL_TEXTURE_1D, 0);
767 gl.texImage1D (GL_TEXTURE_1D, 0, GL_RGBA, 0, 0, GL_RGBA, GL_UNSIGNED_BYTE, DE_NULL);
768 gl.texParameteri (GL_TEXTURE_1D, GL_TEXTURE_MIN_FILTER, GL_LINEAR_MIPMAP_NEAREST);
769 gl.texParameteri (GL_TEXTURE_1D, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
770 gl.texParameterfv (GL_TEXTURE_1D, GL_TEXTURE_BORDER_COLOR, &borderColor[0]);
771 gl.texParameteri (GL_TEXTURE_1D, GL_TEXTURE_WRAP_S, GL_REPEAT);
772 gl.texParameterf (GL_TEXTURE_1D, GL_TEXTURE_MIN_LOD, -1000.0f);
773 gl.texParameterf (GL_TEXTURE_1D, GL_TEXTURE_MAX_LOD, 1000.0f);
774 gl.texParameteri (GL_TEXTURE_1D, GL_TEXTURE_BASE_LEVEL, 0);
775 gl.texParameteri (GL_TEXTURE_1D, GL_TEXTURE_MAX_LEVEL, 1000);
776 gl.texParameterf (GL_TEXTURE_1D, GL_TEXTURE_LOD_BIAS, 0.0f);
777 gl.texParameteri (GL_TEXTURE_1D, GL_TEXTURE_COMPARE_MODE, GL_NONE);
778 gl.texParameteri (GL_TEXTURE_1D, GL_TEXTURE_COMPARE_FUNC, GL_LEQUAL);
779
780 if (contextSupports(type, ApiType::core(3,3)))
781 {
782 gl.texParameteri(GL_TEXTURE_1D, GL_TEXTURE_SWIZZLE_R, GL_RED);
783 gl.texParameteri(GL_TEXTURE_1D, GL_TEXTURE_SWIZZLE_G, GL_GREEN);
784 gl.texParameteri(GL_TEXTURE_1D, GL_TEXTURE_SWIZZLE_B, GL_BLUE);
785 gl.texParameteri(GL_TEXTURE_1D, GL_TEXTURE_SWIZZLE_A, GL_ALPHA);
786 }
787
788 // Reset 2D texture.
789 gl.bindTexture (GL_TEXTURE_2D, 0);
790 gl.texImage2D (GL_TEXTURE_2D, 0, GL_RGBA, 0, 0, 0, GL_RGBA, GL_UNSIGNED_BYTE, DE_NULL);
791 gl.texParameteri (GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR_MIPMAP_NEAREST);
792 gl.texParameteri (GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
793 gl.texParameterfv (GL_TEXTURE_2D, GL_TEXTURE_BORDER_COLOR, &borderColor[0]);
794 gl.texParameteri (GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_REPEAT);
795 gl.texParameteri (GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_REPEAT);
796 gl.texParameterf (GL_TEXTURE_2D, GL_TEXTURE_MIN_LOD, -1000.0f);
797 gl.texParameterf (GL_TEXTURE_2D, GL_TEXTURE_MAX_LOD, 1000.0f);
798 gl.texParameteri (GL_TEXTURE_2D, GL_TEXTURE_BASE_LEVEL, 0);
799 gl.texParameteri (GL_TEXTURE_2D, GL_TEXTURE_MAX_LEVEL, 1000);
800 gl.texParameterf (GL_TEXTURE_2D, GL_TEXTURE_LOD_BIAS, 0.0f);
801 gl.texParameteri (GL_TEXTURE_2D, GL_TEXTURE_COMPARE_MODE, GL_NONE);
802 gl.texParameteri (GL_TEXTURE_2D, GL_TEXTURE_COMPARE_FUNC, GL_LEQUAL);
803
804 if (contextSupports(type, ApiType::core(3,3)))
805 {
806 gl.texParameteri(GL_TEXTURE_2D, GL_TEXTURE_SWIZZLE_R, GL_RED);
807 gl.texParameteri(GL_TEXTURE_2D, GL_TEXTURE_SWIZZLE_G, GL_GREEN);
808 gl.texParameteri(GL_TEXTURE_2D, GL_TEXTURE_SWIZZLE_B, GL_BLUE);
809 gl.texParameteri(GL_TEXTURE_2D, GL_TEXTURE_SWIZZLE_A, GL_ALPHA);
810 }
811
812 // Reset cube map texture.
813 gl.bindTexture (GL_TEXTURE_CUBE_MAP, 0);
814 gl.texImage2D (GL_TEXTURE_CUBE_MAP_POSITIVE_X, 0, GL_RGBA, 0, 0, 0, GL_RGBA, GL_UNSIGNED_BYTE, DE_NULL);
815 gl.texImage2D (GL_TEXTURE_CUBE_MAP_NEGATIVE_X, 0, GL_RGBA, 0, 0, 0, GL_RGBA, GL_UNSIGNED_BYTE, DE_NULL);
816 gl.texImage2D (GL_TEXTURE_CUBE_MAP_POSITIVE_Y, 0, GL_RGBA, 0, 0, 0, GL_RGBA, GL_UNSIGNED_BYTE, DE_NULL);
817 gl.texImage2D (GL_TEXTURE_CUBE_MAP_NEGATIVE_Y, 0, GL_RGBA, 0, 0, 0, GL_RGBA, GL_UNSIGNED_BYTE, DE_NULL);
818 gl.texImage2D (GL_TEXTURE_CUBE_MAP_POSITIVE_Z, 0, GL_RGBA, 0, 0, 0, GL_RGBA, GL_UNSIGNED_BYTE, DE_NULL);
819 gl.texImage2D (GL_TEXTURE_CUBE_MAP_NEGATIVE_Z, 0, GL_RGBA, 0, 0, 0, GL_RGBA, GL_UNSIGNED_BYTE, DE_NULL);
820 gl.texParameteri (GL_TEXTURE_CUBE_MAP, GL_TEXTURE_MIN_FILTER, GL_LINEAR_MIPMAP_NEAREST);
821 gl.texParameteri (GL_TEXTURE_CUBE_MAP, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
822 gl.texParameterfv (GL_TEXTURE_CUBE_MAP, GL_TEXTURE_BORDER_COLOR, &borderColor[0]);
823 gl.texParameteri (GL_TEXTURE_CUBE_MAP, GL_TEXTURE_WRAP_S, GL_REPEAT);
824 gl.texParameteri (GL_TEXTURE_CUBE_MAP, GL_TEXTURE_WRAP_T, GL_REPEAT);
825 gl.texParameterf (GL_TEXTURE_CUBE_MAP, GL_TEXTURE_MIN_LOD, -1000.0f);
826 gl.texParameterf (GL_TEXTURE_CUBE_MAP, GL_TEXTURE_MAX_LOD, 1000.0f);
827 gl.texParameteri (GL_TEXTURE_CUBE_MAP, GL_TEXTURE_BASE_LEVEL, 0);
828 gl.texParameteri (GL_TEXTURE_CUBE_MAP, GL_TEXTURE_MAX_LEVEL, 1000);
829 gl.texParameterf (GL_TEXTURE_CUBE_MAP, GL_TEXTURE_LOD_BIAS, 0.0f);
830 gl.texParameteri (GL_TEXTURE_CUBE_MAP, GL_TEXTURE_COMPARE_MODE, GL_NONE);
831 gl.texParameteri (GL_TEXTURE_CUBE_MAP, GL_TEXTURE_COMPARE_FUNC, GL_LEQUAL);
832
833 if (contextSupports(type, ApiType::core(3,3)))
834 {
835 gl.texParameteri(GL_TEXTURE_CUBE_MAP, GL_TEXTURE_SWIZZLE_R, GL_RED);
836 gl.texParameteri(GL_TEXTURE_CUBE_MAP, GL_TEXTURE_SWIZZLE_G, GL_GREEN);
837 gl.texParameteri(GL_TEXTURE_CUBE_MAP, GL_TEXTURE_SWIZZLE_B, GL_BLUE);
838 gl.texParameteri(GL_TEXTURE_CUBE_MAP, GL_TEXTURE_SWIZZLE_A, GL_ALPHA);
839 }
840
841 // Reset 1D array texture.
842 gl.bindTexture (GL_TEXTURE_1D_ARRAY, 0);
843 gl.texImage2D (GL_TEXTURE_1D_ARRAY, 0, GL_RGBA, 0, 0, 0, GL_RGBA, GL_UNSIGNED_BYTE, DE_NULL);
844 gl.texParameteri (GL_TEXTURE_1D_ARRAY, GL_TEXTURE_MIN_FILTER, GL_LINEAR_MIPMAP_NEAREST);
845 gl.texParameteri (GL_TEXTURE_1D_ARRAY, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
846 gl.texParameterfv (GL_TEXTURE_1D_ARRAY, GL_TEXTURE_BORDER_COLOR, &borderColor[0]);
847 gl.texParameteri (GL_TEXTURE_1D_ARRAY, GL_TEXTURE_WRAP_S, GL_REPEAT);
848 gl.texParameterf (GL_TEXTURE_1D_ARRAY, GL_TEXTURE_MIN_LOD, -1000.0f);
849 gl.texParameterf (GL_TEXTURE_1D_ARRAY, GL_TEXTURE_MAX_LOD, 1000.0f);
850 gl.texParameteri (GL_TEXTURE_1D_ARRAY, GL_TEXTURE_BASE_LEVEL, 0);
851 gl.texParameteri (GL_TEXTURE_1D_ARRAY, GL_TEXTURE_MAX_LEVEL, 1000);
852 gl.texParameterf (GL_TEXTURE_1D_ARRAY, GL_TEXTURE_LOD_BIAS, 0.0f);
853 gl.texParameteri (GL_TEXTURE_1D_ARRAY, GL_TEXTURE_COMPARE_MODE, GL_NONE);
854 gl.texParameteri (GL_TEXTURE_1D_ARRAY, GL_TEXTURE_COMPARE_FUNC, GL_LEQUAL);
855
856 if (contextSupports(type, ApiType::core(3,3)))
857 {
858 gl.texParameteri(GL_TEXTURE_1D_ARRAY, GL_TEXTURE_SWIZZLE_R, GL_RED);
859 gl.texParameteri(GL_TEXTURE_1D_ARRAY, GL_TEXTURE_SWIZZLE_G, GL_GREEN);
860 gl.texParameteri(GL_TEXTURE_1D_ARRAY, GL_TEXTURE_SWIZZLE_B, GL_BLUE);
861 gl.texParameteri(GL_TEXTURE_1D_ARRAY, GL_TEXTURE_SWIZZLE_A, GL_ALPHA);
862 }
863
864 // Reset 2D array texture.
865 gl.bindTexture (GL_TEXTURE_2D_ARRAY, 0);
866 gl.texImage3D (GL_TEXTURE_2D_ARRAY, 0, GL_RGBA, 0, 0, 0, 0, GL_RGBA, GL_UNSIGNED_BYTE, DE_NULL);
867 gl.texParameteri (GL_TEXTURE_2D_ARRAY, GL_TEXTURE_MIN_FILTER, GL_LINEAR_MIPMAP_NEAREST);
868 gl.texParameteri (GL_TEXTURE_2D_ARRAY, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
869 gl.texParameterfv (GL_TEXTURE_2D_ARRAY, GL_TEXTURE_BORDER_COLOR, &borderColor[0]);
870 gl.texParameteri (GL_TEXTURE_2D_ARRAY, GL_TEXTURE_WRAP_S, GL_REPEAT);
871 gl.texParameteri (GL_TEXTURE_2D_ARRAY, GL_TEXTURE_WRAP_T, GL_REPEAT);
872 gl.texParameterf (GL_TEXTURE_2D_ARRAY, GL_TEXTURE_MIN_LOD, -1000.0f);
873 gl.texParameterf (GL_TEXTURE_2D_ARRAY, GL_TEXTURE_MAX_LOD, 1000.0f);
874 gl.texParameteri (GL_TEXTURE_2D_ARRAY, GL_TEXTURE_BASE_LEVEL, 0);
875 gl.texParameteri (GL_TEXTURE_2D_ARRAY, GL_TEXTURE_MAX_LEVEL, 1000);
876 gl.texParameterf (GL_TEXTURE_2D_ARRAY, GL_TEXTURE_LOD_BIAS, 0.0f);
877 gl.texParameteri (GL_TEXTURE_2D_ARRAY, GL_TEXTURE_COMPARE_MODE, GL_NONE);
878 gl.texParameteri (GL_TEXTURE_2D_ARRAY, GL_TEXTURE_COMPARE_FUNC, GL_LEQUAL);
879
880 if (contextSupports(type, ApiType::core(3,3)))
881 {
882 gl.texParameteri(GL_TEXTURE_2D_ARRAY, GL_TEXTURE_SWIZZLE_R, GL_RED);
883 gl.texParameteri(GL_TEXTURE_2D_ARRAY, GL_TEXTURE_SWIZZLE_G, GL_GREEN);
884 gl.texParameteri(GL_TEXTURE_2D_ARRAY, GL_TEXTURE_SWIZZLE_B, GL_BLUE);
885 gl.texParameteri(GL_TEXTURE_2D_ARRAY, GL_TEXTURE_SWIZZLE_A, GL_ALPHA);
886 }
887
888 // Reset 3D texture.
889 gl.bindTexture (GL_TEXTURE_3D, 0);
890 gl.texImage3D (GL_TEXTURE_3D, 0, GL_RGBA, 0, 0, 0, 0, GL_RGBA, GL_UNSIGNED_BYTE, DE_NULL);
891 gl.texParameteri (GL_TEXTURE_3D, GL_TEXTURE_MIN_FILTER, GL_LINEAR_MIPMAP_NEAREST);
892 gl.texParameteri (GL_TEXTURE_3D, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
893 gl.texParameterfv (GL_TEXTURE_3D, GL_TEXTURE_BORDER_COLOR, &borderColor[0]);
894 gl.texParameteri (GL_TEXTURE_3D, GL_TEXTURE_WRAP_S, GL_REPEAT);
895 gl.texParameteri (GL_TEXTURE_3D, GL_TEXTURE_WRAP_T, GL_REPEAT);
896 gl.texParameteri (GL_TEXTURE_3D, GL_TEXTURE_WRAP_R, GL_REPEAT);
897 gl.texParameterf (GL_TEXTURE_3D, GL_TEXTURE_MIN_LOD, -1000.0f);
898 gl.texParameterf (GL_TEXTURE_3D, GL_TEXTURE_MAX_LOD, 1000.0f);
899 gl.texParameteri (GL_TEXTURE_3D, GL_TEXTURE_BASE_LEVEL, 0);
900 gl.texParameteri (GL_TEXTURE_3D, GL_TEXTURE_MAX_LEVEL, 1000);
901 gl.texParameterf (GL_TEXTURE_3D, GL_TEXTURE_LOD_BIAS, 0.0f);
902 gl.texParameteri (GL_TEXTURE_3D, GL_TEXTURE_COMPARE_MODE, GL_NONE);
903 gl.texParameteri (GL_TEXTURE_3D, GL_TEXTURE_COMPARE_FUNC, GL_LEQUAL);
904
905 if (contextSupports(type, ApiType::core(3,3)))
906 {
907 gl.texParameteri(GL_TEXTURE_3D, GL_TEXTURE_SWIZZLE_R, GL_RED);
908 gl.texParameteri(GL_TEXTURE_3D, GL_TEXTURE_SWIZZLE_G, GL_GREEN);
909 gl.texParameteri(GL_TEXTURE_3D, GL_TEXTURE_SWIZZLE_B, GL_BLUE);
910 gl.texParameteri(GL_TEXTURE_3D, GL_TEXTURE_SWIZZLE_A, GL_ALPHA);
911 }
912
913 if (contextSupports(type, ApiType::core(3,1)))
914 {
915 // Reset rectangle texture.
916 gl.bindTexture (GL_TEXTURE_RECTANGLE, 0);
917 gl.texImage2D (GL_TEXTURE_RECTANGLE, 0, GL_RGBA, 0, 0, 0, GL_RGBA, GL_UNSIGNED_BYTE, DE_NULL);
918 gl.texParameteri (GL_TEXTURE_RECTANGLE, GL_TEXTURE_MIN_FILTER, GL_LINEAR);
919 gl.texParameteri (GL_TEXTURE_RECTANGLE, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
920 gl.texParameterfv (GL_TEXTURE_RECTANGLE, GL_TEXTURE_BORDER_COLOR, &borderColor[0]);
921 gl.texParameteri (GL_TEXTURE_RECTANGLE, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE);
922 gl.texParameteri (GL_TEXTURE_RECTANGLE, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE);
923 gl.texParameteri (GL_TEXTURE_RECTANGLE, GL_TEXTURE_BASE_LEVEL, 0);
924 gl.texParameteri (GL_TEXTURE_RECTANGLE, GL_TEXTURE_MAX_LEVEL, 1000);
925 gl.texParameteri (GL_TEXTURE_RECTANGLE, GL_TEXTURE_COMPARE_MODE, GL_NONE);
926 gl.texParameteri (GL_TEXTURE_RECTANGLE, GL_TEXTURE_COMPARE_FUNC, GL_LEQUAL);
927 // \todo [2013-06-17 pyry] Drivers don't accept GL_MIN_LOD, GL_MAX_LOD for rectangle textures. Is that okay?
928
929 if (contextSupports(type, ApiType::core(3,3)))
930 {
931 gl.texParameteri(GL_TEXTURE_RECTANGLE, GL_TEXTURE_SWIZZLE_R, GL_RED);
932 gl.texParameteri(GL_TEXTURE_RECTANGLE, GL_TEXTURE_SWIZZLE_G, GL_GREEN);
933 gl.texParameteri(GL_TEXTURE_RECTANGLE, GL_TEXTURE_SWIZZLE_B, GL_BLUE);
934 gl.texParameteri(GL_TEXTURE_RECTANGLE, GL_TEXTURE_SWIZZLE_A, GL_ALPHA);
935 }
936
937 // Reset buffer texture.
938 gl.bindTexture (GL_TEXTURE_BUFFER, 0);
939 gl.texBuffer (GL_TEXTURE_BUFFER, GL_R8, 0);
940 // \todo [2013-05-04 pyry] Which parameters apply to buffer textures?
941 }
942
943 if (contextSupports(type, ApiType::core(3,2)))
944 {
945 // Reset 2D multisample texture.
946 gl.bindTexture (GL_TEXTURE_2D_MULTISAMPLE, 0);
947 gl.texImage2DMultisample (GL_TEXTURE_2D_MULTISAMPLE, 1, GL_RGBA8, 0, 0, GL_TRUE);
948
949 // Reset 2D multisample array texture.
950 gl.bindTexture (GL_TEXTURE_2D_MULTISAMPLE_ARRAY, 0);
951 gl.texImage3DMultisample (GL_TEXTURE_2D_MULTISAMPLE_ARRAY, 1, GL_RGBA8, 0, 0, 0, GL_TRUE);
952 }
953 }
954
955 gl.activeTexture(GL_TEXTURE0);
956
957 if (contextSupports(type, ApiType::core(3,3)))
958 {
959 for (int ndx = 0; ndx < numTexUnits; ndx++)
960 gl.bindSampler(ndx, 0);
961
962 gl.disable(GL_TEXTURE_CUBE_MAP_SEAMLESS);
963 }
964
965 GLU_EXPECT_NO_ERROR(gl.getError(), "Texture state reset failed");
966 }
967
968 // Pixel operations.
969 {
970 const tcu::RenderTarget& renderTarget = renderCtx.getRenderTarget();
971
972 gl.disable (GL_SCISSOR_TEST);
973 gl.scissor (0, 0, renderTarget.getWidth(), renderTarget.getHeight());
974
975 gl.disable (GL_STENCIL_TEST);
976 gl.stencilFunc (GL_ALWAYS, 0, ~0u);
977 gl.stencilOp (GL_KEEP, GL_KEEP, GL_KEEP);
978
979 gl.disable (GL_DEPTH_TEST);
980 gl.depthFunc (GL_LESS);
981
982 gl.disable (GL_BLEND);
983 gl.blendFunc (GL_ONE, GL_ZERO);
984 gl.blendEquation(GL_FUNC_ADD);
985 gl.blendColor (0.0f, 0.0f, 0.0f, 0.0f);
986
987 gl.disable (GL_FRAMEBUFFER_SRGB);
988 gl.enable (GL_DITHER);
989
990 gl.disable (GL_COLOR_LOGIC_OP);
991 gl.logicOp (GL_COPY);
992
993 GLU_EXPECT_NO_ERROR(gl.getError(), "Pixel operation state reset failed");
994 }
995
996 // Framebuffer control.
997 {
998 gl.colorMask (GL_TRUE, GL_TRUE, GL_TRUE, GL_TRUE);
999 gl.depthMask (GL_TRUE);
1000 gl.stencilMask (~0u);
1001
1002 gl.clearColor (0.0f, 0.0f, 0.0f, 0.0f);
1003 gl.clearDepth (1.0);
1004 gl.clearStencil (0);
1005
1006 GLU_EXPECT_NO_ERROR(gl.getError(), "Framebuffer control state reset failed");
1007 }
1008
1009 // Framebuffer state.
1010 {
1011 const deUint32 framebuffer = renderCtx.getDefaultFramebuffer();
1012
1013 gl.bindFramebuffer(GL_FRAMEBUFFER, framebuffer);
1014
1015 if (framebuffer == 0)
1016 {
1017 gl.drawBuffer(GL_BACK);
1018 gl.readBuffer(GL_BACK);
1019
1020 // This is a workaround for supporting single-buffered configurations.
1021 // Since there is no other place where we need to know if we are dealing
1022 // with single-buffered config, it is not worthwhile to add additional
1023 // state into RenderContext for that.
1024 if (gl.getError() != GL_NO_ERROR)
1025 {
1026 gl.drawBuffer(GL_FRONT);
1027 gl.readBuffer(GL_FRONT);
1028 }
1029 }
1030 else
1031 {
1032 gl.drawBuffer(GL_COLOR_ATTACHMENT0);
1033 gl.readBuffer(GL_COLOR_ATTACHMENT0);
1034 }
1035
1036 GLU_EXPECT_NO_ERROR(gl.getError(), "Framebuffer state reset failed");
1037 }
1038
1039 // Renderbuffer state.
1040 {
1041 gl.bindRenderbuffer(GL_RENDERBUFFER, 0);
1042 GLU_EXPECT_NO_ERROR(gl.getError(), "Renderbuffer state reset failed");
1043 }
1044
1045 // Pixel transfer state.
1046 {
1047 gl.pixelStorei (GL_UNPACK_SWAP_BYTES, GL_FALSE);
1048 gl.pixelStorei (GL_UNPACK_LSB_FIRST, GL_FALSE);
1049 gl.pixelStorei (GL_UNPACK_IMAGE_HEIGHT, 0);
1050 gl.pixelStorei (GL_UNPACK_SKIP_IMAGES, 0);
1051 gl.pixelStorei (GL_UNPACK_ROW_LENGTH, 0);
1052 gl.pixelStorei (GL_UNPACK_SKIP_ROWS, 0);
1053 gl.pixelStorei (GL_UNPACK_SKIP_PIXELS, 0);
1054 gl.pixelStorei (GL_UNPACK_ALIGNMENT, 4);
1055
1056 gl.pixelStorei (GL_PACK_SWAP_BYTES, GL_FALSE);
1057 gl.pixelStorei (GL_PACK_LSB_FIRST, GL_FALSE);
1058 gl.pixelStorei (GL_PACK_IMAGE_HEIGHT, 0);
1059 gl.pixelStorei (GL_PACK_SKIP_IMAGES, 0);
1060 gl.pixelStorei (GL_PACK_ROW_LENGTH, 0);
1061 gl.pixelStorei (GL_PACK_SKIP_ROWS, 0);
1062 gl.pixelStorei (GL_PACK_SKIP_PIXELS, 0);
1063 gl.pixelStorei (GL_PACK_ALIGNMENT, 4);
1064
1065 gl.bindBuffer (GL_PIXEL_PACK_BUFFER, 0);
1066 gl.bindBuffer (GL_PIXEL_UNPACK_BUFFER, 0);
1067
1068 GLU_EXPECT_NO_ERROR(gl.getError(), "Pixel transfer state reset failed");
1069 }
1070
1071 // Program object state.
1072 {
1073 gl.useProgram(0);
1074
1075 if (contextSupports(type, ApiType::core(3,1)))
1076 {
1077 int maxUniformBufferBindings = 0;
1078 gl.getIntegerv(GL_MAX_UNIFORM_BUFFER_BINDINGS, &maxUniformBufferBindings);
1079
1080 gl.bindBuffer(GL_UNIFORM_BUFFER, 0);
1081
1082 for (int ndx = 0; ndx < maxUniformBufferBindings; ndx++)
1083 gl.bindBufferBase(GL_UNIFORM_BUFFER, ndx, 0);
1084 }
1085
1086 GLU_EXPECT_NO_ERROR(gl.getError(), "Program object state reset failed");
1087 }
1088
1089 // Vertex shader state.
1090 {
1091 int numVertexAttribArrays = 0;
1092 gl.getIntegerv(GL_MAX_VERTEX_ATTRIBS, &numVertexAttribArrays);
1093
1094 for (int ndx = 0; ndx < numVertexAttribArrays; ndx++)
1095 gl.vertexAttrib4f(ndx, 0.0f, 0.0f, 0.0f, 1.0f);
1096
1097 gl.disable(GL_VERTEX_PROGRAM_POINT_SIZE);
1098
1099 GLU_EXPECT_NO_ERROR(gl.getError(), "Vertex shader state reset failed");
1100 }
1101
1102 // Transform feedback state.
1103 {
1104 int numTransformFeedbackSeparateAttribs = 0;
1105 gl.getIntegerv(GL_MAX_TRANSFORM_FEEDBACK_SEPARATE_ATTRIBS, &numTransformFeedbackSeparateAttribs);
1106
1107 if (contextSupports(type, ApiType::core(4,0)))
1108 {
1109 glw::GLboolean transformFeedbackActive = 0;
1110 gl.getBooleanv(GL_TRANSFORM_FEEDBACK_ACTIVE, &transformFeedbackActive);
1111
1112 if (transformFeedbackActive)
1113 gl.endTransformFeedback();
1114 }
1115
1116 gl.bindBuffer(GL_TRANSFORM_FEEDBACK_BUFFER, 0);
1117
1118 for (int ndx = 0; ndx < numTransformFeedbackSeparateAttribs; ndx++)
1119 gl.bindBufferBase(GL_TRANSFORM_FEEDBACK_BUFFER, ndx, 0);
1120
1121 GLU_EXPECT_NO_ERROR(gl.getError(), "Transform feedback state reset failed");
1122 }
1123
1124 // Asynchronous query state.
1125 {
1126 deUint32 queryTargets[8];
1127 int numTargets = 0;
1128
1129 queryTargets[numTargets++] = GL_PRIMITIVES_GENERATED;
1130 queryTargets[numTargets++] = GL_TRANSFORM_FEEDBACK_PRIMITIVES_WRITTEN;
1131 queryTargets[numTargets++] = GL_SAMPLES_PASSED;
1132
1133 DE_ASSERT(numTargets <= DE_LENGTH_OF_ARRAY(queryTargets));
1134
1135 for (int i = 0; i < numTargets; i++)
1136 {
1137 int queryActive = 0;
1138 gl.getQueryiv(queryTargets[i], GL_CURRENT_QUERY, &queryActive);
1139
1140 if (queryActive != 0)
1141 gl.endQuery(queryTargets[i]);
1142 }
1143
1144 GLU_EXPECT_NO_ERROR(gl.getError(), "Asynchronous query state reset failed");
1145 }
1146
1147 // Hints.
1148 {
1149 gl.hint(GL_LINE_SMOOTH_HINT, GL_DONT_CARE);
1150 gl.hint(GL_POLYGON_SMOOTH_HINT, GL_DONT_CARE);
1151 gl.hint(GL_TEXTURE_COMPRESSION_HINT, GL_DONT_CARE);
1152 gl.hint(GL_FRAGMENT_SHADER_DERIVATIVE_HINT, GL_DONT_CARE);
1153
1154 GLU_EXPECT_NO_ERROR(gl.getError(), "Hints reset failed");
1155 }
1156
1157 // Buffer copy state.
1158 if (contextSupports(type, ApiType::core(3,1)))
1159 {
1160 gl.bindBuffer(GL_COPY_READ_BUFFER, 0);
1161 gl.bindBuffer(GL_COPY_WRITE_BUFFER, 0);
1162
1163 GLU_EXPECT_NO_ERROR(gl.getError(), "Buffer copy state reset failed");
1164 }
1165
1166 // Debug state
1167 if (ctxInfo.isExtensionSupported("GL_KHR_debug"))
1168 {
1169 const bool entrypointsPresent = gl.debugMessageControl != DE_NULL &&
1170 gl.debugMessageCallback != DE_NULL;
1171
1172 // some drivers advertise GL_KHR_debug but give out null pointers. Silently ignore.
1173 if (entrypointsPresent)
1174 {
1175 gl.debugMessageControl(GL_DONT_CARE, GL_DONT_CARE, GL_DONT_CARE, 0, DE_NULL, true);
1176 gl.debugMessageControl(GL_DONT_CARE, GL_DONT_CARE, GL_DEBUG_SEVERITY_LOW, 0, DE_NULL, false);
1177 gl.debugMessageCallback(DE_NULL, DE_NULL);
1178
1179 if (type.getFlags() & glu::CONTEXT_DEBUG)
1180 gl.enable(GL_DEBUG_OUTPUT);
1181 else
1182 gl.disable(GL_DEBUG_OUTPUT);
1183 }
1184 }
1185 }
1186
resetState(const RenderContext & renderCtx,const ContextInfo & ctxInfo)1187 void resetState (const RenderContext& renderCtx, const ContextInfo& ctxInfo)
1188 {
1189 if (isContextTypeES(renderCtx.getType()))
1190 resetStateES(renderCtx, ctxInfo);
1191 else if (isContextTypeGLCore(renderCtx.getType()))
1192 resetStateGLCore(renderCtx, ctxInfo);
1193 else
1194 throw tcu::InternalError("State reset requested for unsupported context type");
1195 }
1196
1197 } // glu
1198