From: Dave Airlie Date: Mon, 14 Oct 2013 07:27:48 +0000 (+1000) Subject: st/mesa: handle layer and primitive id output and point size input X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=530afc82a117f5318820189db5fcd4bdad97f829;p=mesa.git st/mesa: handle layer and primitive id output and point size input This fixes a number of piglit crashes when running on a hacked up llvmpipe. Signed-off-by: Dave Airlie Reviewed-by: Brian Paul --- diff --git a/src/mesa/state_tracker/st_program.c b/src/mesa/state_tracker/st_program.c index 5efd6141d0c..f010e1889f8 100644 --- a/src/mesa/state_tracker/st_program.c +++ b/src/mesa/state_tracker/st_program.c @@ -923,6 +923,10 @@ st_translate_geometry_program(struct st_context *st, stgp->input_semantic_name[slot] = TGSI_SEMANTIC_CLIPDIST; stgp->input_semantic_index[slot] = 1; break; + case VARYING_SLOT_PSIZ: + stgp->input_semantic_name[slot] = TGSI_SEMANTIC_PSIZE; + stgp->input_semantic_index[slot] = 0; + break; case VARYING_SLOT_TEX0: case VARYING_SLOT_TEX1: case VARYING_SLOT_TEX2: @@ -1007,6 +1011,14 @@ st_translate_geometry_program(struct st_context *st, gs_output_semantic_name[slot] = TGSI_SEMANTIC_CLIPDIST; gs_output_semantic_index[slot] = 1; break; + case VARYING_SLOT_LAYER: + gs_output_semantic_name[slot] = TGSI_SEMANTIC_LAYER; + gs_output_semantic_index[slot] = 0; + break; + case VARYING_SLOT_PRIMITIVE_ID: + gs_output_semantic_name[slot] = TGSI_SEMANTIC_PRIMID; + gs_output_semantic_index[slot] = 0; + break; case VARYING_SLOT_TEX0: case VARYING_SLOT_TEX1: case VARYING_SLOT_TEX2: