constant tracking
authorBen Skeggs <darktama@iinet.net.au>
Thu, 26 May 2005 02:33:57 +0000 (02:33 +0000)
committerBen Skeggs <darktama@iinet.net.au>
Thu, 26 May 2005 02:33:57 +0000 (02:33 +0000)
src/mesa/drivers/dri/r300/r300_context.h
src/mesa/drivers/dri/r300/r300_fragprog.c
src/mesa/drivers/dri/r300/r300_state.c

index ebe6553..befb19e 100644 (file)
@@ -637,13 +637,17 @@ struct r300_fragment_program {
        int tex_offset;
        int tex_end;
 
+       /* Hardware constants */
+       GLfloat constant[PFS_NUM_CONST_REGS][4];
+       int const_nr;
+
+       /* Tracked parameters */
        struct {
-               float x;
-               float y;
-               float z;
-               float w;
-       } param[32];
-       int param_length;
+               int idx;                        /* hardware index */
+               GLfloat *values;        /* pointer to values */
+       } param[PFS_NUM_CONST_REGS];
+       int param_nr;
+       GLboolean params_uptodate;
        
        GLuint temps[PFS_NUM_TEMP_REGS];
        int temp_in_use;
@@ -654,6 +658,7 @@ struct r300_fragment_program {
        int hwreg_in_use;
        int max_temp_idx;
 };
+
 #else
 /* 64 appears to be the maximum */
 #define PSF_MAX_PROGRAM_LENGTH 64
index fc10e36..7090756 100644 (file)
@@ -248,33 +248,41 @@ static void free_temp(struct r300_fragment_program *rp, pfs_reg_t r)
        rp->temp_in_use &= ~(1<<r.index);
 }
 
-static pfs_reg_t emit_const4fv(struct r300_fragment_program *rp, GLfloat *cp)
-{ 
+static pfs_reg_t emit_param4fv(struct r300_fragment_program *rp, GLfloat *values)
+{
        pfs_reg_t r = pfs_default_reg;
+               r.type = REG_TYPE_CONST;
+       int pidx;
+
+       pidx = rp->param_nr++;
+       r.index = rp->const_nr++;
+       if (pidx >= PFS_NUM_CONST_REGS || r.index >= PFS_NUM_CONST_REGS) {
+               ERROR("Out of const/param slots!\n");
+               return r;
+       }
        
-       r.type = REG_TYPE_CONST;
+       rp->param[pidx].idx = r.index;
+       rp->param[pidx].values = values;
+       rp->params_uptodate = GL_FALSE;
+
        r.valid = GL_TRUE;
+       return r;
+}
 
-       if (cp[0] == 1.0 && cp[1] == 1.0 && cp[2] == 1.0 && cp[3] == 1.0) {
-               r.v_swz = SWIZZLE_111;
-               r.s_swz = SWIZZLE_ONE;
-               r.index = 0;
-       } else if (cp[0] == 0.0 && cp[1] == 0.0 && cp[2] == 0.0 && cp[3] == 0.0) {
-               r.v_swz = SWIZZLE_000;
-               r.s_swz = SWIZZLE_ZERO;
-               r.index = 0;
-       } else if (cp[0] == 0.5 && cp[1] == 0.5 && cp[2] == 0.5 && cp[3] == 0.5) {
-               r.v_swz = SWIZZLE_HHH;
-               r.s_swz = SWIZZLE_HALF;
-               r.index = 0;
-       } else {
-               r.index = rp->param_length++;
-               rp->param[r.index].x = cp[0];
-               rp->param[r.index].y = cp[1];
-               rp->param[r.index].z = cp[2];
-               rp->param[r.index].w = cp[3];
+static pfs_reg_t emit_const4fv(struct r300_fragment_program *rp, GLfloat *cp)
+{ 
+       pfs_reg_t r = pfs_default_reg;
+               r.type = REG_TYPE_CONST;
+
+       r.index = rp->const_nr++;
+       if (r.index >= PFS_NUM_CONST_REGS) {
+               ERROR("Out of hw constants!\n");
+               return r;
        }
+       
+       COPY_4V(rp->constant[r.index], cp);
 
+       r.valid = GL_TRUE;
        return r;
 }
 
@@ -404,14 +412,14 @@ static pfs_reg_t t_src(struct r300_fragment_program *rp,
                r.valid = GL_TRUE;
                break;
        case PROGRAM_LOCAL_PARAM:
-               r = emit_const4fv(rp, rp->mesa_program.Base.LocalParams[fpsrc.Index]);
+               r = emit_param4fv(rp, rp->mesa_program.Base.LocalParams[fpsrc.Index]);
                break;
        case PROGRAM_ENV_PARAM:
-               r = emit_const4fv(rp, rp->ctx->FragmentProgram.Parameters[fpsrc.Index]);
+               r = emit_param4fv(rp, rp->ctx->FragmentProgram.Parameters[fpsrc.Index]);
                break;
        case PROGRAM_STATE_VAR:
        case PROGRAM_NAMED_PARAM:
-               r = emit_const4fv(rp, rp->mesa_program.Parameters->ParameterValues[fpsrc.Index]);
+               r = emit_param4fv(rp, rp->mesa_program.Parameters->ParameterValues[fpsrc.Index]);
                break;
        default:
                ERROR("unknown SrcReg->File %x\n", fpsrc.File);
@@ -873,7 +881,10 @@ void init_program(struct r300_fragment_program *rp)
        rp->used_in_node = 0;
        rp->dest_in_node = 0;
 
-       rp->param_length = 0;
+       rp->const_nr = 0;
+       rp->param_nr = 0;
+       rp->params_uptodate = GL_FALSE;
+
        rp->temp_in_use = 0;
        rp->hwreg_in_use = 0;
        rp->max_temp_idx = 0;
@@ -936,32 +947,47 @@ void init_program(struct r300_fragment_program *rp)
                }
        }
        rp->temp_in_use = temps_used;
+}
+
+void update_params(struct r300_fragment_program *rp) {
+       struct fragment_program *mp = &rp->mesa_program;
+       int i;
 
        /* Ask Mesa nicely to fill in ParameterValues for us */
-       _mesa_load_state_parameters(rp->ctx, rp->mesa_program.Parameters);
+       if (rp->param_nr)
+               _mesa_load_state_parameters(rp->ctx, mp->Parameters);
+
+       for (i=0;i<rp->param_nr;i++)
+               COPY_4V(rp->constant[rp->param[i].idx], rp->param[i].values);
+
+       rp->params_uptodate = GL_TRUE;
 }
 
 void translate_fragment_shader(struct r300_fragment_program *rp)
 {
        int i;
 
-       init_program(rp);
+       if (!rp->translated) {
+               init_program(rp);
        
-       if (parse_program(rp) == GL_FALSE) {
-               dump_program(rp);
-               return;
-       }
+               if (parse_program(rp) == GL_FALSE) {
+                       dump_program(rp);
+                       return;
+               }
 
-       /* Finish off */
-       sync_streams(rp);
-       rp->node[rp->cur_node].alu_end  = rp->v_pos - 1;
-       rp->alu_offset                                  = 0;
-       rp->alu_end                                             = rp->v_pos - 1;
-       rp->tex_offset                                  = 0;
-       rp->tex_end                                             = rp->tex.length - 1;
+               /* Finish off */
+               sync_streams(rp);
+               rp->node[rp->cur_node].alu_end  = rp->v_pos - 1;
+               rp->alu_offset                                  = 0;
+               rp->alu_end                                             = rp->v_pos - 1;
+               rp->tex_offset                                  = 0;
+               rp->tex_end                                             = rp->tex.length - 1;
+       
+               rp->translated = GL_TRUE;
+               if (0) dump_program(rp);
+       }
 
-       rp->translated = GL_TRUE;
-       if (0) dump_program(rp);
+       update_params(rp);
 }
 
 /* just some random things... */
index b143ad2..6a14231 100644 (file)
@@ -1573,12 +1573,10 @@ void r300SetupPixelShader(r300ContextPtr rmesa)
        if (!rp)        /* should only happenen once, just after context is created */
                return;
        
+       translate_fragment_shader(ctx->FragmentProgram._Current);
        if (!rp->translated) {
-               translate_fragment_shader(ctx->FragmentProgram._Current);
-               if (!rp->translated) {
-                       fprintf(stderr, "%s: No valid fragment shader, exiting\n", __func__);
-                       exit(-1);
-               }
+               fprintf(stderr, "%s: No valid fragment shader, exiting\n", __func__);
+               exit(-1);
        }
        
        R300_STATECHANGE(rmesa, fpt);
@@ -1627,13 +1625,13 @@ void r300SetupPixelShader(r300ContextPtr rmesa)
                | (rp->tex_end << R300_PFS_CNTL_TEX_END_SHIFT);
 
        R300_STATECHANGE(rmesa, fpp);
-       for(i=0;i<rp->param_length;i++){
-               rmesa->hw.fpp.cmd[R300_FPP_PARAM_0+4*i+0]=r300PackFloat24(rp->param[i].x);
-               rmesa->hw.fpp.cmd[R300_FPP_PARAM_0+4*i+1]=r300PackFloat24(rp->param[i].y);
-               rmesa->hw.fpp.cmd[R300_FPP_PARAM_0+4*i+2]=r300PackFloat24(rp->param[i].z);
-               rmesa->hw.fpp.cmd[R300_FPP_PARAM_0+4*i+3]=r300PackFloat24(rp->param[i].w);
+       for(i=0;i<rp->const_nr;i++){
+               rmesa->hw.fpp.cmd[R300_FPP_PARAM_0+4*i+0]=r300PackFloat24(rp->constant[i][0]);
+               rmesa->hw.fpp.cmd[R300_FPP_PARAM_0+4*i+1]=r300PackFloat24(rp->constant[i][1]);
+               rmesa->hw.fpp.cmd[R300_FPP_PARAM_0+4*i+2]=r300PackFloat24(rp->constant[i][2]);
+               rmesa->hw.fpp.cmd[R300_FPP_PARAM_0+4*i+3]=r300PackFloat24(rp->constant[i][3]);
        }
-       rmesa->hw.fpp.cmd[R300_FPP_CMD_0]=cmducs(R300_PFS_PARAM_0_X, rp->param_length*4);
+       rmesa->hw.fpp.cmd[R300_FPP_CMD_0]=cmducs(R300_PFS_PARAM_0_X, rp->const_nr*4);
 }
 #else
 /* just a skeleton for now.. */
@@ -1818,7 +1816,7 @@ int i,k;
 static void r300InvalidateState(GLcontext * ctx, GLuint new_state)
 {
        r300ContextPtr r300 = R300_CONTEXT(ctx);
-
+       
        _swrast_InvalidateState(ctx, new_state);
        _swsetup_InvalidateState(ctx, new_state);
        _ac_InvalidateState(ctx, new_state);