diff options
author | Rob Clark <[email protected]> | 2019-08-01 08:31:25 -0700 |
---|---|---|
committer | Rob Clark <[email protected]> | 2019-08-13 08:11:26 -0700 |
commit | f0b91730a14bab95e5a59f62cb0159d549a5750e (patch) | |
tree | 972df2d3cdb639e60d7d4309022263fbf268a7b9 /src/gallium/drivers/freedreno/a6xx | |
parent | 53667a43c4fbe0a902b5516ff263cfcb07ee1175 (diff) |
freedreno/a6xx: stop using ir3_emit_{vs,fs}_consts()
Should be no functional change. Next step is to re-arrange various
const state into different stateobjs.
Signed-off-by: Rob Clark <[email protected]>
Diffstat (limited to 'src/gallium/drivers/freedreno/a6xx')
-rw-r--r-- | src/gallium/drivers/freedreno/a6xx/fd6_emit.c | 25 |
1 files changed, 23 insertions, 2 deletions
diff --git a/src/gallium/drivers/freedreno/a6xx/fd6_emit.c b/src/gallium/drivers/freedreno/a6xx/fd6_emit.c index 956e6dfb405..69d0c3eee95 100644 --- a/src/gallium/drivers/freedreno/a6xx/fd6_emit.c +++ b/src/gallium/drivers/freedreno/a6xx/fd6_emit.c @@ -934,7 +934,19 @@ fd6_emit_state(struct fd_ringbuffer *ring, struct fd6_emit *emit) struct fd_ringbuffer *vsconstobj = fd_submit_new_ringbuffer( ctx->batch->submit, 0x1000, FD_RINGBUFFER_STREAMING); - ir3_emit_vs_consts(vp, vsconstobj, ctx, emit->info); + ir3_emit_user_consts(ctx->screen, vp, vsconstobj, + &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, + &ctx->shaderimg[PIPE_SHADER_VERTEX]); + + if (ir3_needs_vs_driver_params(vp)) + ir3_emit_vs_driver_params(vp, vsconstobj, ctx, emit->info); + fd6_emit_add_group(emit, vsconstobj, FD6_GROUP_VS_CONST, 0x7); fd_ringbuffer_del(vsconstobj); } @@ -943,7 +955,16 @@ fd6_emit_state(struct fd_ringbuffer *ring, struct fd6_emit *emit) struct fd_ringbuffer *fsconstobj = fd_submit_new_ringbuffer( ctx->batch->submit, 0x1000, FD_RINGBUFFER_STREAMING); - ir3_emit_fs_consts(fp, fsconstobj, ctx); + ir3_emit_user_consts(ctx->screen, fp, fsconstobj, + &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, + &ctx->shaderimg[PIPE_SHADER_FRAGMENT]); + fd6_emit_add_group(emit, fsconstobj, FD6_GROUP_FS_CONST, 0x6); fd_ringbuffer_del(fsconstobj); } |