glsl/ast: Check that geometry shader interface block inputs are arrays.
authorPaul Berry <stereotype441@gmail.com>
Mon, 12 Aug 2013 13:39:23 +0000 (06:39 -0700)
committerPaul Berry <stereotype441@gmail.com>
Wed, 14 Aug 2013 03:02:54 +0000 (20:02 -0700)
Reviewed-by: Kenneth Graunke <kenneth@whitecape.org>
src/glsl/ast_to_hir.cpp

index 49804b7..3610014 100644 (file)
@@ -4528,6 +4528,19 @@ ast_interface_block::hir(exec_list *instructions,
     */
    assert(declared_variables.is_empty());
 
+   /* From section 4.3.4 (Inputs) of the GLSL 1.50 spec:
+    *
+    *     Geometry shader input variables get the per-vertex values written
+    *     out by vertex shader output variables of the same names. Since a
+    *     geometry shader operates on a set of vertices, each input varying
+    *     variable (or input block, see interface blocks below) needs to be
+    *     declared as an array.
+    */
+   if (state->target == geometry_shader && !this->is_array &&
+       var_mode == ir_var_shader_in) {
+      _mesa_glsl_error(&loc, state, "geometry shader inputs must be arrays");
+   }
+
    /* Page 39 (page 45 of the PDF) of section 4.3.7 in the GLSL ES 3.00 spec
     * says:
     *