From: Rob Clark Date: Thu, 1 Aug 2019 15:35:14 +0000 (-0700) Subject: freedreno/a6xx: move immediates to program stateobj X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=7f1e3391c6d2baae60dd797cd05aaff730ab5110;p=mesa.git freedreno/a6xx: move immediates to program stateobj Signed-off-by: Rob Clark --- diff --git a/src/gallium/drivers/freedreno/a6xx/fd6_emit.c b/src/gallium/drivers/freedreno/a6xx/fd6_emit.c index 69d0c3eee95..7b858106910 100644 --- a/src/gallium/drivers/freedreno/a6xx/fd6_emit.c +++ b/src/gallium/drivers/freedreno/a6xx/fd6_emit.c @@ -938,7 +938,6 @@ fd6_emit_state(struct fd_ringbuffer *ring, struct fd6_emit *emit) &ctx->constbuf[PIPE_SHADER_VERTEX]); ir3_emit_ubos(ctx->screen, vp, vsconstobj, &ctx->constbuf[PIPE_SHADER_VERTEX]); - ir3_emit_immediates(ctx->screen, vp, vsconstobj); ir3_emit_ssbo_sizes(ctx->screen, vp, vsconstobj, &ctx->shaderbuf[PIPE_SHADER_VERTEX]); ir3_emit_image_dims(ctx->screen, vp, vsconstobj, @@ -959,7 +958,6 @@ fd6_emit_state(struct fd_ringbuffer *ring, struct fd6_emit *emit) &ctx->constbuf[PIPE_SHADER_FRAGMENT]); ir3_emit_ubos(ctx->screen, fp, fsconstobj, &ctx->constbuf[PIPE_SHADER_FRAGMENT]); - ir3_emit_immediates(ctx->screen, fp, fsconstobj); ir3_emit_ssbo_sizes(ctx->screen, fp, fsconstobj, &ctx->shaderbuf[PIPE_SHADER_FRAGMENT]); ir3_emit_image_dims(ctx->screen, fp, fsconstobj, diff --git a/src/gallium/drivers/freedreno/a6xx/fd6_program.c b/src/gallium/drivers/freedreno/a6xx/fd6_program.c index 7714f569f96..3aa91c312b3 100644 --- a/src/gallium/drivers/freedreno/a6xx/fd6_program.c +++ b/src/gallium/drivers/freedreno/a6xx/fd6_program.c @@ -251,8 +251,9 @@ next_regid(uint32_t reg, uint32_t increment) } static void -setup_stateobj(struct fd_ringbuffer *ring, struct fd6_program_state *state, - const struct ir3_shader_key *key, bool binning_pass) +setup_stateobj(struct fd_ringbuffer *ring, struct fd_screen *screen, + struct fd6_program_state *state, const struct ir3_shader_key *key, + bool binning_pass) { uint32_t pos_regid, psize_regid, color_regid[8], posz_regid; uint32_t face_regid, coord_regid, zwcoord_regid, samp_id_regid; @@ -585,6 +586,10 @@ setup_stateobj(struct fd_ringbuffer *ring, struct fd6_program_state *state, OUT_PKT4(ring, REG_A6XX_GRAS_SU_DEPTH_PLANE_CNTL, 1); OUT_RING(ring, COND(fragz, A6XX_GRAS_SU_DEPTH_PLANE_CNTL_FRAG_WRITES_Z)); + + ir3_emit_immediates(screen, vs, ring); + if (!binning_pass) + ir3_emit_immediates(screen, fs, ring); } /* emits the program state which is not part of the stateobj because of @@ -699,8 +704,8 @@ fd6_program_create(void *data, struct ir3_shader_variant *bs, state->stateobj = fd_ringbuffer_new_object(ctx->pipe, 0x1000); setup_config_stateobj(state->config_stateobj, state); - setup_stateobj(state->binning_stateobj, state, key, true); - setup_stateobj(state->stateobj, state, key, false); + setup_stateobj(state->binning_stateobj, ctx->screen, state, key, true); + setup_stateobj(state->stateobj, ctx->screen, state, key, false); return &state->base; }