[Piglit] [PATCH 01/10] util: Add support for separate shader objects to piglit_draw_rect_from_arrays

Ian Romanick idr at freedesktop.org
Sun Apr 27 14:12:04 PDT 2014


From: Ian Romanick <ian.d.romanick at intel.com>

Previosly it only looked at GL_CURRENT_PROGRAM to determine whether the
active vertex shader used piglit_vertex as an input.  With
ARB_separate_shader_objects, it also needs to look at the
GL_VERTEX_SHADER associated with the current
GL_PROGRAM_PIPELINE_BINDING.

Signed-off-by: Ian Romanick <ian.d.romanick at intel.com>
---
 tests/util/piglit-util-gl-common.c | 19 +++++++++++++++++++
 1 file changed, 19 insertions(+)

diff --git a/tests/util/piglit-util-gl-common.c b/tests/util/piglit-util-gl-common.c
index 4abbd57..45ca099 100644
--- a/tests/util/piglit-util-gl-common.c
+++ b/tests/util/piglit-util-gl-common.c
@@ -608,6 +608,25 @@ piglit_draw_rect_from_arrays(const void *verts, const void *tex)
 
 		glGetIntegerv(GL_CURRENT_PROGRAM, (GLint *) &prog);
 
+		/* If no there is no program bound to the traditional,
+		 * monolithic program binding pipe (via glUseProgram), get the
+		 * vertex shader program attached to the current program
+		 * pipeline.
+		 */
+		if (prog == 0 &&
+		    (piglit_get_gl_version() >= 42
+		     || piglit_is_extension_supported("GL_ARB_separate_shader_objects"))) {
+			GLuint pipe;
+
+			glGetIntegerv(GL_PROGRAM_PIPELINE_BINDING,
+				      (GLint *) &pipe);
+			if (pipe != 0)
+				glGetProgramPipelineiv(pipe,
+						       GL_VERTEX_SHADER,
+						       (GLint *) &prog);
+		}
+
+
 		/* If there is a current program and that program has an
 		 * active attribute named piglit_vertex, don't use the fixed
 		 * function inputs.
-- 
1.8.1.4



More information about the Piglit mailing list