Browse Source

zink: more batch-ism

Acked-by: Jordan Justen <jordan.l.justen@intel.com>
tags/19.3-branchpoint
Erik Faye-Lund 6 years ago
parent
commit
9e0ff0ffda

+ 2
- 2
src/gallium/drivers/zink/zink_batch.c View File

@@ -37,7 +37,7 @@ reset_batch(struct zink_screen *screen, struct zink_batch *batch)
}

void
zink_start_cmdbuf(struct zink_context *ctx, struct zink_batch *batch)
zink_start_batch(struct zink_context *ctx, struct zink_batch *batch)
{
reset_batch(zink_screen(ctx->base.screen), batch);

@@ -72,7 +72,7 @@ submit_cmdbuf(struct zink_context *ctx, VkCommandBuffer cmdbuf, VkFence fence)
}

void
zink_end_cmdbuf(struct zink_context *ctx, struct zink_batch *batch)
zink_end_batch(struct zink_context *ctx, struct zink_batch *batch)
{
if (vkEndCommandBuffer(batch->cmdbuf) != VK_SUCCESS) {
debug_printf("vkEndCommandBuffer failed\n");

+ 2
- 2
src/gallium/drivers/zink/zink_batch.h View File

@@ -47,10 +47,10 @@ struct zink_batch {
};

void
zink_start_cmdbuf(struct zink_context *ctx, struct zink_batch *batch);
zink_start_batch(struct zink_context *ctx, struct zink_batch *batch);

void
zink_end_cmdbuf(struct zink_context *ctx, struct zink_batch *batch);
zink_end_batch(struct zink_context *ctx, struct zink_batch *batch);

void
zink_batch_reference_resoure(struct zink_batch *cmdbuf,

+ 8
- 13
src/gallium/drivers/zink/zink_context.c View File

@@ -506,15 +506,6 @@ get_framebuffer(struct zink_context *ctx)
return entry->data;
}

static void
end_batch(struct zink_context *ctx, struct zink_batch *batch)
{
if (batch->rp)
vkCmdEndRenderPass(batch->cmdbuf);

zink_end_cmdbuf(ctx, batch);
}

void
zink_begin_render_pass(struct zink_context *ctx, struct zink_batch *batch)
{
@@ -546,14 +537,18 @@ zink_begin_render_pass(struct zink_context *ctx, struct zink_batch *batch)
static void
flush_batch(struct zink_context *ctx)
{
end_batch(ctx, zink_context_curr_batch(ctx));
struct zink_batch *batch = zink_context_curr_batch(ctx);
if (batch->rp)
vkCmdEndRenderPass(batch->cmdbuf);

zink_end_batch(ctx, batch);

ctx->curr_batch++;
if (ctx->curr_batch == ARRAY_SIZE(ctx->batches))
ctx->curr_batch = 0;

struct zink_batch *batch = zink_context_curr_batch(ctx);
zink_start_cmdbuf(ctx, batch);
batch = zink_context_curr_batch(ctx);
zink_start_batch(ctx, batch);
}

static void
@@ -1385,7 +1380,7 @@ zink_context_create(struct pipe_screen *pscreen, void *priv, unsigned flags)
ctx->dirty = ZINK_DIRTY_PROGRAM;

/* start the first batch */
zink_start_cmdbuf(ctx, zink_context_curr_batch(ctx));
zink_start_batch(ctx, zink_context_curr_batch(ctx));

return &ctx->base;


Loading…
Cancel
Save