diff options
author | Marek Olšák <[email protected]> | 2017-04-09 13:17:54 +0200 |
---|---|---|
committer | Marek Olšák <[email protected]> | 2017-05-10 19:00:16 +0200 |
commit | c334c7dd7598a3a95ab10273950317fb6e3d949c (patch) | |
tree | 3b37af684e775fc05d888b91f233203e8a774683 /src | |
parent | 330d0607ed60fd3edca192e54b4246310f06652f (diff) |
st/mesa: don't call util_draw_init_info in st_draw_vbo
Diffstat (limited to 'src')
-rw-r--r-- | src/mesa/state_tracker/st_draw.c | 10 |
1 files changed, 8 insertions, 2 deletions
diff --git a/src/mesa/state_tracker/st_draw.c b/src/mesa/state_tracker/st_draw.c index 3fee0cd1425..8b657be6bc0 100644 --- a/src/mesa/state_tracker/st_draw.c +++ b/src/mesa/state_tracker/st_draw.c @@ -166,7 +166,11 @@ st_draw_vbo(struct gl_context *ctx, return; } - util_draw_init_info(&info); + /* Initialize pipe_draw_info. */ + info.primitive_restart = false; + info.vertices_per_patch = ctx->TessCtrlProgram.patch_vertices; + info.indirect = NULL; + info.count_from_stream_output = NULL; if (ib) { struct gl_buffer_object *bufobj = ib->obj; @@ -183,6 +187,7 @@ st_draw_vbo(struct gl_context *ctx, if (_mesa_is_bufferobj(bufobj)) { /* indices are in a real VBO */ + info.has_user_indices = false; info.index.resource = st_buffer_object(bufobj)->buffer; start = pointer_to_offset(ib->ptr) / info.index_size; } else { @@ -194,6 +199,8 @@ st_draw_vbo(struct gl_context *ctx, setup_primitive_restart(ctx, &info); } else { + info.index_size = 0; + /* Transform feedback drawing is always non-indexed. */ /* Set info.count_from_stream_output. */ if (tfb_vertcount) { @@ -211,7 +218,6 @@ st_draw_vbo(struct gl_context *ctx, info.count = prims[i].count; info.start_instance = prims[i].base_instance; info.instance_count = prims[i].num_instances; - info.vertices_per_patch = ctx->TessCtrlProgram.patch_vertices; info.index_bias = prims[i].basevertex; info.drawid = prims[i].draw_id; if (!ib) { |