<div dir="ltr"><br><div class="gmail_extra"><br><div class="gmail_quote">On Tue, Oct 18, 2016 at 8:28 AM, Jason Ekstrand <span dir="ltr"><<a href="mailto:jason@jlekstrand.net" target="_blank">jason@jlekstrand.net</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div class="gmail_extra"><div class="gmail_quote"><span class="">On Tue, Oct 18, 2016 at 8:14 AM, Jason Ekstrand <span dir="ltr"><<a href="mailto:jason@jlekstrand.net" target="_blank">jason@jlekstrand.net</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div><div><div><div><div>I want to make a few comments on how this series is structured.  This is not the way I would have done it and I think the way you structured it makes it substantially less rebasable than it could be and a bit harder to review.  The way *I* would have done this would be something like the following:<br><br></div><div> 1) Move shader_info to common code (patches 1-2)<br></div><div> 2) Add a shader_info pointer to gl_program (patch 6), break the fill shader_info stuff from glsl_to_nir into its own function, and call it from somewhere such that it always gets filled out.<br></div> 3) Add new fields to shader_info *and* make sure they get filled out from other GLSL information<br></div> 4) Convert i965 over to the new shader_info<br></div> 5) Convert gallium over to the new shader_info<br></div> 6) Make GLSL fill out shader_info directly and nuke the old shader metadata.<br></div><div> 7) Delete the shader_info fill-out function.<br></div></div></blockquote></span></div></div></div></blockquote><div><br></div><div>Oh, and one more step:<br><br></div><div> 8) Refactor to get rid of all of the gl_foo_program stuff.  (Maybe multiple patches?)<br></div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div class="gmail_extra"><div class="gmail_quote"><span class=""><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div></div><div><br></div>Something along these lines would go a long way towards avoiding the "mega patch" problem where each patch touches 4 or 5 different components.  It also makes it clearer to review because you don't add fields and then the reviewer goes "Wait, where does this get set?  Oh, in another patch".  I'm not necessarily saying that you have to go back and change your patches.  It's more a suggestion for if you end up doing a v3 or another refactor along these lines in the future.</div></blockquote><div><br></div></span><div>On the review side, splitting out as I described above would make it much easier to review since it would be more-or-less one type of refactor per patch.  In this patch, we have several different kinds of refactors:<br><br></div><div> 1) Move consumers over to reading shader_info<br></div><div> 2) Remove gl_tess_ctrl_program and related refactors<br></div><div> 3) Move producer over to writing shader_info<br><br></div><div>Normally, when reviewing, I would just skim (2) and give (1) a (3) more effort.  Having them mixed together means I have to pay constant attention to what's going on.  Also, having (2) mixed in makes it harder to verify (3) because there's a lot of code motion only some of which matters.<br></div><div><div class="h5"><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div><div class="m_-4982087022489176131h5"><br><div><div><div><div><div><div><div><div><div class="gmail_extra"><br><div class="gmail_quote">On Mon, Oct 17, 2016 at 11:12 PM, Timothy Arceri <span dir="ltr"><<a href="mailto:timothy.arceri@collabora.com" target="_blank">timothy.arceri@collabora.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">---<br>
 src/mesa/drivers/dri/i965/brw<wbr>_context.h           |  6 ++---<br>
 src/mesa/drivers/dri/i965/brw<wbr>_draw.c              |  2 +-<br>
 src/mesa/drivers/dri/i965/brw<wbr>_program.c           |  2 +-<br>
 src/mesa/drivers/dri/i965/brw<wbr>_tcs.c               | 32 ++++++++++-------------<br>
 src/mesa/drivers/dri/i965/brw<wbr>_tcs_surface_state.c |  2 +-<br>
 src/mesa/drivers/dri/i965/brw<wbr>_tes.c               | 20 +++++++-------<br>
 src/mesa/drivers/dri/i965/gen<wbr>7_hs_state.c         |  4 +--<br>
 src/mesa/main/context.c                           |  2 +-<br>
 src/mesa/main/mtypes.h                            | 12 +--------<br>
 src/mesa/main/shaderapi.c                         |  4 +--<br>
 src/mesa/main/state.c                             | 11 ++++----<br>
 src/mesa/program/prog_stateva<wbr>rs.c                 |  2 +-<br>
 src/mesa/program/program.c                        |  4 +--<br>
 src/mesa/program/program.h                        | 23 ----------------<br>
 src/mesa/state_tracker/st_ato<wbr>m.c                  |  2 +-<br>
 src/mesa/state_tracker/st_ato<wbr>m_constbuf.c         |  2 +-<br>
 src/mesa/state_tracker/st_ato<wbr>m_sampler.c          |  2 +-<br>
 src/mesa/state_tracker/st_ato<wbr>m_shader.c           |  2 +-<br>
 src/mesa/state_tracker/st_ato<wbr>m_texture.c          |  2 +-<br>
 src/mesa/state_tracker/st_cb_<wbr>program.c            | 10 +++----<br>
 src/mesa/state_tracker/st_pro<wbr>gram.c               |  6 ++---<br>
 src/mesa/state_tracker/st_pro<wbr>gram.h               |  6 ++---<br>
 22 files changed, 58 insertions(+), 100 deletions(-)<br>
<br>
diff --git a/src/mesa/drivers/dri/i965/br<wbr>w_context.h b/src/mesa/drivers/dri/i965/br<wbr>w_context.h<br>
index c92bb9f..9b7e184 100644<br>
--- a/src/mesa/drivers/dri/i965/br<wbr>w_context.h<br>
+++ b/src/mesa/drivers/dri/i965/br<wbr>w_context.h<br>
@@ -337,7 +337,7 @@ struct brw_vertex_program {<br>
<br>
 /** Subclass of Mesa tessellation control program */<br>
 struct brw_tess_ctrl_program {<br>
-   struct gl_tess_ctrl_program program;<br>
+   struct gl_program program;<br>
    unsigned id;  /**< serial no. to identify tess ctrl progs, never re-used */<br>
 };<br>
<br>
@@ -1008,7 +1008,7 @@ struct brw_context<br>
     */<br>
    const struct gl_vertex_program *vertex_program;<br>
    const struct gl_geometry_program *geometry_program;<br>
-   const struct gl_tess_ctrl_program *tess_ctrl_program;<br>
+   const struct gl_program *tess_ctrl_program;<br>
    const struct gl_tess_eval_program *tess_eval_program;<br>
    const struct gl_fragment_program *fragment_program;<br>
    const struct gl_compute_program *compute_program;<br>
@@ -1730,7 +1730,7 @@ brw_vertex_program_const(const struct gl_vertex_program *p)<br>
 }<br>
<br>
 static inline struct brw_tess_ctrl_program *<br>
-brw_tess_ctrl_program(struct gl_tess_ctrl_program *p)<br>
+brw_tess_ctrl_program(struct gl_program *p)<br>
 {<br>
    return (struct brw_tess_ctrl_program *) p;<br>
 }<br>
diff --git a/src/mesa/drivers/dri/i965/br<wbr>w_draw.c b/src/mesa/drivers/dri/i965/br<wbr>w_draw.c<br>
index 5d176ef..5485de3 100644<br>
--- a/src/mesa/drivers/dri/i965/br<wbr>w_draw.c<br>
+++ b/src/mesa/drivers/dri/i965/br<wbr>w_draw.c<br>
@@ -458,7 +458,7 @@ brw_try_draw_prims(struct gl_context *ctx,<br>
    brw->tes.base.sampler_count = ctx->TessEvalProgram._Current ?<br>
       util_last_bit(ctx->TessEvalPr<wbr>ogram._Current->Base.SamplersU<wbr>sed) : 0;<br>
    brw->tcs.base.sampler_count = ctx->TessCtrlProgram._Current ?<br>
-      util_last_bit(ctx->TessCtrlPro<wbr>gram._Current->Base.SamplersUs<wbr>ed) : 0;<br>
+      util_last_bit(ctx->TessCtrlPro<wbr>gram._Current->SamplersUsed) : 0;<br>
    brw->vs.base.sampler_count =<br>
       util_last_bit(ctx->VertexProg<wbr>ram._Current->Base.SamplersUse<wbr>d);<br>
<br>
diff --git a/src/mesa/drivers/dri/i965/br<wbr>w_program.c b/src/mesa/drivers/dri/i965/br<wbr>w_program.c<br>
index a41f36e..4e0df5a 100644<br>
--- a/src/mesa/drivers/dri/i965/br<wbr>w_program.c<br>
+++ b/src/mesa/drivers/dri/i965/br<wbr>w_program.c<br>
@@ -168,7 +168,7 @@ static struct gl_program *brwNewProgram( struct gl_context *ctx,<br>
       if (prog) {<br>
          prog->id = get_new_program_id(brw->screen<wbr>);<br>
<br>
-         return _mesa_init_gl_program(&prog->p<wbr>rogram.Base, target, id);<br>
+         return _mesa_init_gl_program(&prog->p<wbr>rogram, target, id);<br>
       } else {<br>
          return NULL;<br>
       }<br>
diff --git a/src/mesa/drivers/dri/i965/br<wbr>w_tcs.c b/src/mesa/drivers/dri/i965/br<wbr>w_tcs.c<br>
index 0f03fab..08cf413 100644<br>
--- a/src/mesa/drivers/dri/i965/br<wbr>w_tcs.c<br>
+++ b/src/mesa/drivers/dri/i965/br<wbr>w_tcs.c<br>
@@ -178,7 +178,7 @@ brw_codegen_tcs_prog(struct brw_context *brw,<br>
    double start_time = 0;<br>
<br>
    if (tcp) {<br>
-      nir = tcp->program.Base.nir;<br>
+      nir = tcp->program.nir;<br>
    } else {<br>
       /* Create a dummy nir_shader.  We won't actually use NIR code to<br>
        * generate assembly (it's easier to generate assembly directly),<br>
@@ -211,14 +211,14 @@ brw_codegen_tcs_prog(struct brw_context *brw,<br>
<br>
    if (tcs) {<br>
       brw_assign_common_binding_tab<wbr>le_offsets(MESA_SHADER_TESS_CT<wbr>RL, devinfo,<br>
-                                              shader_prog, &tcp->program.Base,<br>
+                                              shader_prog, &tcp->program,<br>
                                               &prog_data.base.base, 0);<br>
<br>
       prog_data.base.base.image_par<wbr>am =<br>
          rzalloc_array(NULL, struct brw_image_param, tcs->NumImages);<br>
       prog_data.base.base.nr_image_<wbr>params = tcs->NumImages;<br>
<br>
-      brw_nir_setup_glsl_uniforms(ni<wbr>r, shader_prog, &tcp->program.Base,<br>
+      brw_nir_setup_glsl_uniforms(ni<wbr>r, shader_prog, &tcp->program,<br>
                                   &prog_data.base.base,<br>
                                   compiler->scalar_stage[MESA_S<wbr>HADER_TESS_CTRL]);<br>
    } else {<br>
@@ -316,24 +316,21 @@ void<br>
 brw_tcs_populate_key(struct brw_context *brw,<br>
                      struct brw_tcs_prog_key *key)<br>
 {<br>
-   uint64_t per_vertex_slots =<br>
-      brw->tess_eval_program->Base.n<wbr>ir->info->inputs_read;<br>
-   uint32_t per_patch_slots =<br>
-      brw->tess_eval_program->Base.n<wbr>ir->info->patch_inputs_read;<br>
-<br>
    struct brw_tess_ctrl_program *tcp =<br>
       (struct brw_tess_ctrl_program *) brw->tess_ctrl_program;<br>
    struct brw_tess_eval_program *tep =<br>
       (struct brw_tess_eval_program *) brw->tess_eval_program;<br>
-   struct gl_program *prog = &tcp->program.Base;<br>
+   struct gl_program *tes_prog = &tep->program;<br>
+<br>
+   uint64_t per_vertex_slots = tes_prog->info.inputs_read;<br>
+   uint32_t per_patch_slots = tes_prog->info.patch_inputs_re<wbr>ad;<br>
<br>
    memset(key, 0, sizeof(*key));<br>
<br>
-   if (brw->tess_ctrl_program) {<br>
-      per_vertex_slots |=<br>
-         brw->tess_ctrl_program->Base.<wbr>nir->info->outputs_written;<br>
-      per_patch_slots |=<br>
-         brw->tess_ctrl_program->Base.<wbr>nir->info->patch_outputs_writt<wbr>en;<br>
+   if (tcp) {<br>
+      struct gl_program *prog = &tcp->program;<br>
+      per_vertex_slots |= prog->info.outputs_written;<br>
+      per_patch_slots |= prog->info.patch_outputs_writt<wbr>en;<br>
    }<br>
<br>
    if (brw->gen < 8 || !tcp)<br>
@@ -353,9 +350,9 @@ brw_tcs_populate_key(struct brw_context *brw,<br>
       key->program_string_id = tcp->id;<br>
<br>
       /* _NEW_TEXTURE */<br>
-      brw_populate_sampler_prog_key_<wbr>data(&brw->ctx, prog, &key->tex);<br>
+      brw_populate_sampler_prog_key_<wbr>data(&brw->ctx, &tcp->program, &key->tex);<br>
    } else {<br>
-      key->outputs_written = tep->program.Base.nir->info->i<wbr>nputs_read;<br>
+      key->outputs_written = tes_prog->info.inputs_read;<br>
    }<br>
 }<br>
<br>
@@ -403,8 +400,7 @@ brw_tcs_precompile(struct gl_context *ctx,<br>
    struct brw_stage_prog_data *old_prog_data = brw->tcs.base.prog_data;<br>
    bool success;<br>
<br>
-   struct gl_tess_ctrl_program *tcp = (struct gl_tess_ctrl_program *)prog;<br>
-   struct brw_tess_ctrl_program *btcp = brw_tess_ctrl_program(tcp);<br>
+   struct brw_tess_ctrl_program *btcp = brw_tess_ctrl_program(prog);<br>
    const struct gl_linked_shader *tes =<br>
       shader_prog->_LinkedShaders[M<wbr>ESA_SHADER_TESS_EVAL];<br>
<br>
diff --git a/src/mesa/drivers/dri/i965/br<wbr>w_tcs_surface_state.c b/src/mesa/drivers/dri/i965/br<wbr>w_tcs_surface_state.c<br>
index 5021e10..e91488f 100644<br>
--- a/src/mesa/drivers/dri/i965/br<wbr>w_tcs_surface_state.c<br>
+++ b/src/mesa/drivers/dri/i965/br<wbr>w_tcs_surface_state.c<br>
@@ -52,7 +52,7 @@ brw_upload_tcs_pull_constants(<wbr>struct brw_context *brw)<br>
<br>
    _mesa_shader_write_subroutine_<wbr>indices(&brw->ctx, MESA_SHADER_TESS_CTRL);<br>
    /* _NEW_PROGRAM_CONSTANTS */<br>
-   brw_upload_pull_constants(brw<wbr>, BRW_NEW_TCS_CONSTBUF, &tcp->program.Base,<br>
+   brw_upload_pull_constants(brw<wbr>, BRW_NEW_TCS_CONSTBUF, &tcp->program,<br>
                              stage_state, prog_data);<br>
 }<br>
<br>
diff --git a/src/mesa/drivers/dri/i965/br<wbr>w_tes.c b/src/mesa/drivers/dri/i965/br<wbr>w_tes.c<br>
index 59e4d50..fe03816 100644<br>
--- a/src/mesa/drivers/dri/i965/br<wbr>w_tes.c<br>
+++ b/src/mesa/drivers/dri/i965/br<wbr>w_tes.c<br>
@@ -233,16 +233,15 @@ void<br>
 brw_tes_populate_key(struct brw_context *brw,<br>
                      struct brw_tes_prog_key *key)<br>
 {<br>
-<br>
-   uint64_t per_vertex_slots =<br>
-      brw->tess_eval_program->Base.n<wbr>ir->info->inputs_read;<br>
-   uint32_t per_patch_slots =<br>
-      brw->tess_eval_program->Base.n<wbr>ir->info->patch_inputs_read;<br>
-<br>
+   struct brw_tess_ctrl_program *tcp =<br>
+      (struct brw_tess_ctrl_program *) brw->tess_ctrl_program;<br>
    struct brw_tess_eval_program *tep =<br>
       (struct brw_tess_eval_program *) brw->tess_eval_program;<br>
    struct gl_program *prog = &tep->program.Base;<br>
<br>
+   uint64_t per_vertex_slots = prog->info.inputs_read;<br>
+   uint32_t per_patch_slots = prog->info.patch_inputs_read;<br>
+<br>
    memset(key, 0, sizeof(*key));<br>
<br>
    key->program_string_id = tep->id;<br>
@@ -251,11 +250,10 @@ brw_tes_populate_key(struct brw_context *brw,<br>
     * TES (possibly for cross-thread communication).  These need to<br>
     * be stored in the Patch URB Entry as well.<br>
     */<br>
-   if (brw->tess_ctrl_program) {<br>
-      per_vertex_slots |=<br>
-         brw->tess_ctrl_program->Base.<wbr>nir->info->outputs_written;<br>
-      per_patch_slots |=<br>
-         brw->tess_ctrl_program->Base.<wbr>nir->info->patch_outputs_writt<wbr>en;<br>
+   if (tcp) {<br>
+      struct gl_program *tcp_prog = &tcp->program;<br>
+      per_vertex_slots |= tcp_prog->info.outputs_written<wbr>;<br>
+      per_patch_slots |= tcp_prog->info.patch_outputs_w<wbr>ritten;<br>
    }<br>
<br>
    /* Ignore gl_TessLevelInner/Outer - we treat them as system values,<br>
diff --git a/src/mesa/drivers/dri/i965/ge<wbr>n7_hs_state.c b/src/mesa/drivers/dri/i965/ge<wbr>n7_hs_state.c<br>
index f16af28..290aea2 100644<br>
--- a/src/mesa/drivers/dri/i965/ge<wbr>n7_hs_state.c<br>
+++ b/src/mesa/drivers/dri/i965/ge<wbr>n7_hs_state.c<br>
@@ -41,8 +41,8 @@ gen7_upload_tcs_push_constants<wbr>(struct brw_context *brw)<br>
       const struct brw_stage_prog_data *prog_data = brw->tcs.base.prog_data;<br>
<br>
       _mesa_shader_write_subroutine<wbr>_indices(&brw->ctx, MESA_SHADER_TESS_CTRL);<br>
-      gen6_upload_push_constants(brw<wbr>, &tcp->program.Base, prog_data,<br>
-                                      stage_state, AUB_TRACE_VS_CONSTANTS);<br>
+      gen6_upload_push_constants(brw<wbr>, &tcp->program, prog_data, stage_state,<br>
+                                 AUB_TRACE_VS_CONSTANTS);<br>
    }<br>
<br>
    gen7_upload_constant_state(brw<wbr>, stage_state, active, _3DSTATE_CONSTANT_HS);<br>
diff --git a/src/mesa/main/context.c b/src/mesa/main/context.c<br>
index 47fd4a0..1e4f87d 100644<br>
--- a/src/mesa/main/context.c<br>
+++ b/src/mesa/main/context.c<br>
@@ -1297,7 +1297,7 @@ _mesa_free_context_data( struct gl_context *ctx )<br>
    _mesa_reference_vertprog(ctx, &ctx->VertexProgram._Current, NULL);<br>
    _mesa_reference_vertprog(ctx, &ctx->VertexProgram._TnlProgra<wbr>m, NULL);<br>
<br>
-   _mesa_reference_tesscprog(ctx<wbr>, &ctx->TessCtrlProgram._Current<wbr>, NULL);<br>
+   _mesa_reference_program(ctx, &ctx->TessCtrlProgram._Current<wbr>, NULL);<br>
    _mesa_reference_tesseprog(ctx, &ctx->TessEvalProgram._Current<wbr>, NULL);<br>
    _mesa_reference_geomprog(ctx, &ctx->GeometryProgram._Current<wbr>, NULL);<br>
<br>
diff --git a/src/mesa/main/mtypes.h b/src/mesa/main/mtypes.h<br>
index 3a517f2..9191130 100644<br>
--- a/src/mesa/main/mtypes.h<br>
+++ b/src/mesa/main/mtypes.h<br>
@@ -1998,16 +1998,6 @@ struct gl_vertex_program<br>
 };<br>
<br>
<br>
-/** Tessellation control program object */<br>
-struct gl_tess_ctrl_program<br>
-{<br>
-   struct gl_program Base;   /**< base class */<br>
-<br>
-   /* output layout */<br>
-   GLint VerticesOut;<br>
-};<br>
-<br>
-<br>
 /** Tessellation evaluation program object */<br>
 struct gl_tess_eval_program<br>
 {<br>
@@ -2138,7 +2128,7 @@ struct gl_vertex_program_state<br>
 struct gl_tess_ctrl_program_state<br>
 {<br>
    /** Currently bound and valid shader. */<br>
-   struct gl_tess_ctrl_program *_Current;<br>
+   struct gl_program *_Current;<br>
<br>
    GLint patch_vertices;<br>
    GLfloat patch_default_outer_level[4];<br>
diff --git a/src/mesa/main/shaderapi.c b/src/mesa/main/shaderapi.c<br>
index c40bb2d..531f8fa 100644<br>
--- a/src/mesa/main/shaderapi.c<br>
+++ b/src/mesa/main/shaderapi.c<br>
@@ -2165,9 +2165,7 @@ _mesa_copy_linked_program_data<wbr>(gl_shader_stage type,<br>
       dst->CullDistanceArraySize = src->Vert.CullDistanceArraySiz<wbr>e;<br>
       break;<br>
    case MESA_SHADER_TESS_CTRL: {<br>
-      struct gl_tess_ctrl_program *dst_tcp =<br>
-         (struct gl_tess_ctrl_program *) dst;<br>
-      dst_tcp->VerticesOut = src->_LinkedShaders[MESA_SHADE<wbr>R_TESS_CTRL]-><br>
+      dst->info.tcs.vertices_out = src->_LinkedShaders[MESA_SHADE<wbr>R_TESS_CTRL]-><br>
          info.TessCtrl.VerticesOut;<br>
       break;<br>
    }<br>
diff --git a/src/mesa/main/state.c b/src/mesa/main/state.c<br>
index bf6035e..b520761 100644<br>
--- a/src/mesa/main/state.c<br>
+++ b/src/mesa/main/state.c<br>
@@ -110,7 +110,7 @@ update_program(struct gl_context *ctx)<br>
    const struct gl_vertex_program *prevVP = ctx->VertexProgram._Current;<br>
    const struct gl_fragment_program *prevFP = ctx->FragmentProgram._Current;<br>
    const struct gl_geometry_program *prevGP = ctx->GeometryProgram._Current;<br>
-   const struct gl_tess_ctrl_program *prevTCP = ctx->TessCtrlProgram._Current;<br>
+   const struct gl_program *prevTCP = ctx->TessCtrlProgram._Current;<br>
    const struct gl_tess_eval_program *prevTEP = ctx->TessEvalProgram._Current;<br>
    const struct gl_compute_program *prevCP = ctx->ComputeProgram._Current;<br>
    GLbitfield new_state = 0x0;<br>
@@ -208,13 +208,12 @@ update_program(struct gl_context *ctx)<br>
    if (tcsProg && tcsProg->LinkStatus<br>
        && tcsProg->_LinkedShaders[MESA_S<wbr>HADER_TESS_CTRL]) {<br>
       /* Use GLSL tessellation control shader */<br>
-      _mesa_reference_tesscprog(ctx, &ctx->TessCtrlProgram._Current<wbr>,<br>
-         gl_tess_ctrl_program(<br>
-            tcsProg->_LinkedShaders[MESA_S<wbr>HADER_TESS_CTRL]->Program));<br>
+      _mesa_reference_program(ctx, &ctx->TessCtrlProgram._Current<wbr>,<br>
+          tcsProg->_LinkedShaders[MESA_S<wbr>HADER_TESS_CTRL]->Program);<br>
    }<br>
    else {<br>
       /* No tessellation control program */<br>
-      _mesa_reference_tesscprog(ctx, &ctx->TessCtrlProgram._Current<wbr>, NULL);<br>
+      _mesa_reference_program(ctx, &ctx->TessCtrlProgram._Current<wbr>, NULL);<br>
    }<br>
<br>
    /* Examine vertex program after fragment program as<br>
@@ -284,7 +283,7 @@ update_program(struct gl_context *ctx)<br>
       new_state |= _NEW_PROGRAM;<br>
       if (ctx->Driver.BindProgram) {<br>
          ctx->Driver.BindProgram(ctx, GL_TESS_CONTROL_PROGRAM_NV,<br>
-                            (struct gl_program *) ctx->TessCtrlProgram._Current)<wbr>;<br>
+                                 ctx->TessCtrlProgram._Current<wbr>);<br>
       }<br>
    }<br>
<br>
diff --git a/src/mesa/program/prog_statev<wbr>ars.c b/src/mesa/program/prog_statev<wbr>ars.c<br>
index 6e6007e..2ac7b56 100644<br>
--- a/src/mesa/program/prog_statev<wbr>ars.c<br>
+++ b/src/mesa/program/prog_statev<wbr>ars.c<br>
@@ -604,7 +604,7 @@ _mesa_fetch_state(struct gl_context *ctx, const gl_state_index state[],<br>
<br>
       case STATE_TES_PATCH_VERTICES_IN:<br>
          if (ctx->TessCtrlProgram._Current<wbr>)<br>
-            val[0].i = ctx->TessCtrlProgram._Current-<wbr>>VerticesOut;<br>
+            val[0].i = ctx->TessCtrlProgram._Current-<wbr>>info.tcs.vertices_out;<br>
          else<br>
             val[0].i = ctx->TessCtrlProgram.patch_ver<wbr>tices;<br>
          return;<br>
diff --git a/src/mesa/program/program.c b/src/mesa/program/program.c<br>
index 6767216..f89a833 100644<br>
--- a/src/mesa/program/program.c<br>
+++ b/src/mesa/program/program.c<br>
@@ -228,8 +228,8 @@ _mesa_new_program(struct gl_context *ctx, GLenum target, GLuint id)<br>
       return _mesa_init_gl_program(&prog->B<wbr>ase, target, id);<br>
    }<br>
    case GL_TESS_CONTROL_PROGRAM_NV: {<br>
-      struct gl_tess_ctrl_program *prog = CALLOC_STRUCT(gl_tess_ctrl_pro<wbr>gram);<br>
-      return _mesa_init_gl_program(&prog->B<wbr>ase, target, id);<br>
+      struct gl_program *prog = CALLOC_STRUCT(gl_program);<br>
+      return _mesa_init_gl_program(prog, target, id);<br>
    }<br>
    case GL_TESS_EVALUATION_PROGRAM_NV: {<br>
       struct gl_tess_eval_program *prog = CALLOC_STRUCT(gl_tess_eval_pro<wbr>gram);<br>
diff --git a/src/mesa/program/program.h b/src/mesa/program/program.h<br>
index 09e6928..d937f82 100644<br>
--- a/src/mesa/program/program.h<br>
+++ b/src/mesa/program/program.h<br>
@@ -125,16 +125,6 @@ _mesa_reference_compprog(struc<wbr>t gl_context *ctx,<br>
                            (struct gl_program *) prog);<br>
 }<br>
<br>
-<br>
-static inline void<br>
-_mesa_reference_tesscprog(str<wbr>uct gl_context *ctx,<br>
-                         struct gl_tess_ctrl_program **ptr,<br>
-                         struct gl_tess_ctrl_program *prog)<br>
-{<br>
-   _mesa_reference_program(ctx, (struct gl_program **) ptr,<br>
-                           (struct gl_program *) prog);<br>
-}<br>
-<br>
 static inline void<br>
 _mesa_reference_tesseprog(str<wbr>uct gl_context *ctx,<br>
                          struct gl_tess_eval_program **ptr,<br>
@@ -267,19 +257,6 @@ gl_compute_program_const(const struct gl_program *prog)<br>
    return (const struct gl_compute_program *) prog;<br>
 }<br>
<br>
-static inline struct gl_tess_ctrl_program *<br>
-gl_tess_ctrl_program(struct gl_program *prog)<br>
-{<br>
-   return (struct gl_tess_ctrl_program *) prog;<br>
-}<br>
-<br>
-static inline const struct gl_tess_ctrl_program *<br>
-gl_tess_ctrl_program_const(co<wbr>nst struct gl_program *prog)<br>
-{<br>
-   return (const struct gl_tess_ctrl_program *) prog;<br>
-}<br>
-<br>
-<br>
 static inline struct gl_tess_eval_program *<br>
 gl_tess_eval_program(struct gl_program *prog)<br>
 {<br>
diff --git a/src/mesa/state_tracker/st_at<wbr>om.c b/src/mesa/state_tracker/st_at<wbr>om.c<br>
index 94e012a..497ba82 100644<br>
--- a/src/mesa/state_tracker/st_at<wbr>om.c<br>
+++ b/src/mesa/state_tracker/st_at<wbr>om.c<br>
@@ -70,7 +70,7 @@ static void check_program_state( struct st_context *st )<br>
    struct st_fragment_program *old_fp = st->fp;<br>
<br>
    struct gl_vertex_program *new_vp = ctx->VertexProgram._Current;<br>
-   struct gl_tess_ctrl_program *new_tcp = ctx->TessCtrlProgram._Current;<br>
+   struct gl_program *new_tcp = ctx->TessCtrlProgram._Current;<br>
    struct gl_tess_eval_program *new_tep = ctx->TessEvalProgram._Current;<br>
    struct gl_geometry_program *new_gp = ctx->GeometryProgram._Current;<br>
    struct gl_fragment_program *new_fp = ctx->FragmentProgram._Current;<br>
diff --git a/src/mesa/state_tracker/st_at<wbr>om_constbuf.c b/src/mesa/state_tracker/st_at<wbr>om_constbuf.c<br>
index 8882582..90d4ffb 100644<br>
--- a/src/mesa/state_tracker/st_at<wbr>om_constbuf.c<br>
+++ b/src/mesa/state_tracker/st_at<wbr>om_constbuf.c<br>
@@ -195,7 +195,7 @@ static void update_tcs_constants(struct st_context *st )<br>
    struct gl_program_parameter_list *params;<br>
<br>
    if (tcp) {<br>
-      params = tcp->Base.Base.Parameters;<br>
+      params = tcp->Base.Parameters;<br>
       st_upload_constants( st, params, MESA_SHADER_TESS_CTRL );<br>
    }<br>
 }<br>
diff --git a/src/mesa/state_tracker/st_at<wbr>om_sampler.c b/src/mesa/state_tracker/st_at<wbr>om_sampler.c<br>
index 065df6d..76b355c 100644<br>
--- a/src/mesa/state_tracker/st_at<wbr>om_sampler.c<br>
+++ b/src/mesa/state_tracker/st_at<wbr>om_sampler.c<br>
@@ -344,7 +344,7 @@ update_samplers(struct st_context *st)<br>
    if (ctx->TessCtrlProgram._Current<wbr>) {<br>
       update_shader_samplers(st,<br>
                              PIPE_SHADER_TESS_CTRL,<br>
-                             &ctx->TessCtrlProgram._Curren<wbr>t->Base,<br>
+                             ctx->TessCtrlProgram._Current<wbr>,<br>
                              ctx->Const.Program[MESA_SHADER<wbr>_TESS_CTRL].MaxTextureImageUni<wbr>ts,<br>
                              st->state.samplers[PIPE_SHADER<wbr>_TESS_CTRL],<br>
                              &st->state.num_samplers[PIPE_S<wbr>HADER_TESS_CTRL]);<br>
diff --git a/src/mesa/state_tracker/st_at<wbr>om_shader.c b/src/mesa/state_tracker/st_at<wbr>om_shader.c<br>
index 2f700a2..0df0770 100644<br>
--- a/src/mesa/state_tracker/st_at<wbr>om_shader.c<br>
+++ b/src/mesa/state_tracker/st_at<wbr>om_shader.c<br>
@@ -254,7 +254,7 @@ update_tcp( struct st_context *st )<br>
    }<br>
<br>
    sttcp = st_tessctrl_program(st->ctx->T<wbr>essCtrlProgram._Current);<br>
-   assert(sttcp->Base.Base.Targe<wbr>t == GL_TESS_CONTROL_PROGRAM_NV);<br>
+   assert(sttcp->Base.Target == GL_TESS_CONTROL_PROGRAM_NV);<br>
<br>
    st->tcp_variant = st_get_basic_variant(st, PIPE_SHADER_TESS_CTRL,<br>
                                           &sttcp->tgsi, &sttcp->variants);<br>
diff --git a/src/mesa/state_tracker/st_at<wbr>om_texture.c b/src/mesa/state_tracker/st_at<wbr>om_texture.c<br>
index c8ae62c..fbd73d6 100644<br>
--- a/src/mesa/state_tracker/st_at<wbr>om_texture.c<br>
+++ b/src/mesa/state_tracker/st_at<wbr>om_texture.c<br>
@@ -253,7 +253,7 @@ update_tessctrl_textures(struc<wbr>t st_context *st)<br>
    if (ctx->TessCtrlProgram._Current<wbr>) {<br>
       update_textures(st,<br>
                       MESA_SHADER_TESS_CTRL,<br>
-                      &ctx->TessCtrlProgram._Current<wbr>->Base,<br>
+                      ctx->TessCtrlProgram._Current,<br>
                       ctx->Const.Program[MESA_SHADE<wbr>R_TESS_CTRL].MaxTextureImageUn<wbr>its,<br>
                       st->state.sampler_views[PIPE_<wbr>SHADER_TESS_CTRL],<br>
                       &st->state.num_sampler_views[<wbr>PIPE_SHADER_TESS_CTRL]);<br>
diff --git a/src/mesa/state_tracker/st_cb<wbr>_program.c b/src/mesa/state_tracker/st_cb<wbr>_program.c<br>
index 1fd5019..c85f0ef 100644<br>
--- a/src/mesa/state_tracker/st_cb<wbr>_program.c<br>
+++ b/src/mesa/state_tracker/st_cb<wbr>_program.c<br>
@@ -71,7 +71,7 @@ st_new_program(struct gl_context *ctx, GLenum target, GLuint id)<br>
    }<br>
    case GL_TESS_CONTROL_PROGRAM_NV: {<br>
       struct st_tessctrl_program *prog = ST_CALLOC_STRUCT(st_tessctrl_p<wbr>rogram);<br>
-      return _mesa_init_gl_program(&prog->B<wbr>ase.Base, target, id);<br>
+      return _mesa_init_gl_program(&prog->B<wbr>ase, target, id);<br>
    }<br>
    case GL_TESS_EVALUATION_PROGRAM_NV: {<br>
       struct st_tesseval_program *prog = ST_CALLOC_STRUCT(st_tesseval_p<wbr>rogram);<br>
@@ -134,8 +134,8 @@ st_delete_program(struct gl_context *ctx, struct gl_program *prog)<br>
          struct st_tessctrl_program *sttcp =<br>
             (struct st_tessctrl_program *) prog;<br>
<br>
-         st_release_basic_variants(st, sttcp->Base.Base.Target,<br>
-                                   &sttcp->variants, &sttcp->tgsi);<br>
+         st_release_basic_variants(st, sttcp->Base.Target, &sttcp->variants,<br>
+                                   &sttcp->tgsi);<br>
<br>
          if (sttcp->glsl_to_tgsi)<br>
             free_glsl_to_tgsi_visitor(stt<wbr>cp->glsl_to_tgsi);<br>
@@ -221,8 +221,8 @@ st_program_string_notify( struct gl_context *ctx,<br>
       struct st_tessctrl_program *sttcp =<br>
          (struct st_tessctrl_program *) prog;<br>
<br>
-      st_release_basic_variants(st, sttcp->Base.Base.Target,<br>
-                                &sttcp->variants, &sttcp->tgsi);<br>
+      st_release_basic_variants(st, sttcp->Base.Target, &sttcp->variants,<br>
+                                &sttcp->tgsi);<br>
       if (!st_translate_tessctrl_progra<wbr>m(st, sttcp))<br>
          return false;<br>
<br>
diff --git a/src/mesa/state_tracker/st_pr<wbr>ogram.c b/src/mesa/state_tracker/st_pr<wbr>ogram.c<br>
index 7cc36b4..cb40211 100644<br>
--- a/src/mesa/state_tracker/st_pr<wbr>ogram.c<br>
+++ b/src/mesa/state_tracker/st_pr<wbr>ogram.c<br>
@@ -1605,10 +1605,10 @@ st_translate_tessctrl_program(<wbr>struct st_context *st,<br>
       return false;<br>
<br>
    ureg_property(ureg, TGSI_PROPERTY_TCS_VERTICES_OUT<wbr>,<br>
-                 sttcp->Base.VerticesOut);<br>
+                 sttcp->Base.info.tcs.vertices<wbr>_out);<br>
<br>
-   st_translate_program_common(s<wbr>t, &sttcp->Base.Base, sttcp->glsl_to_tgsi,<br>
-                               ureg, PIPE_SHADER_TESS_CTRL, &sttcp->tgsi);<br>
+   st_translate_program_common(s<wbr>t, &sttcp->Base, sttcp->glsl_to_tgsi, ureg,<br>
+                               PIPE_SHADER_TESS_CTRL, &sttcp->tgsi);<br>
<br>
    free_glsl_to_tgsi_visitor(sttc<wbr>p->glsl_to_tgsi);<br>
    sttcp->glsl_to_tgsi = NULL;<br>
diff --git a/src/mesa/state_tracker/st_pr<wbr>ogram.h b/src/mesa/state_tracker/st_pr<wbr>ogram.h<br>
index ea55d47..b801891 100644<br>
--- a/src/mesa/state_tracker/st_pr<wbr>ogram.h<br>
+++ b/src/mesa/state_tracker/st_pr<wbr>ogram.h<br>
@@ -260,11 +260,11 @@ struct st_geometry_program<br>
<br>
<br>
 /**<br>
- * Derived from Mesa gl_tess_ctrl_program:<br>
+ * Derived from Mesa gl_program:<br>
  */<br>
 struct st_tessctrl_program<br>
 {<br>
-   struct gl_tess_ctrl_program Base;  /**< The Mesa tess ctrl program */<br>
+   struct gl_program Base;  /**< The Mesa tess ctrl program */<br>
    struct pipe_shader_state tgsi;<br>
    struct glsl_to_tgsi_visitor* glsl_to_tgsi;<br>
    uint64_t affected_states; /**< ST_NEW_* flags to mark dirty when binding */<br>
@@ -321,7 +321,7 @@ st_geometry_program( struct gl_geometry_program *gp )<br>
 }<br>
<br>
 static inline struct st_tessctrl_program *<br>
-st_tessctrl_program( struct gl_tess_ctrl_program *tcp )<br>
+st_tessctrl_program( struct gl_program *tcp )<br>
 {<br>
    return (struct st_tessctrl_program *)tcp;<br>
 }<br>
<span class="m_-4982087022489176131m_2818256755971515239HOEnZb"><font color="#888888">--<br>
2.7.4<br>
<br>
______________________________<wbr>_________________<br>
mesa-dev mailing list<br>
<a href="mailto:mesa-dev@lists.freedesktop.org" target="_blank">mesa-dev@lists.freedesktop.org</a><br>
<a href="https://lists.freedesktop.org/mailman/listinfo/mesa-dev" rel="noreferrer" target="_blank">https://lists.freedesktop.org/<wbr>mailman/listinfo/mesa-dev</a><br>
</font></span></blockquote></div><br></div></div></div></div></div></div></div></div></div></div></div></div>
</blockquote></div></div></div><br></div></div>
</blockquote></div><br></div></div>