From e4018fdd85d8b58250c2cff8cdf4edd6b2b3c70b Mon Sep 17 00:00:00 2001 From: =?utf8?q?Marek=20Ol=C5=A1=C3=A1k?= Date: Fri, 1 Sep 2017 23:27:35 +0200 Subject: [PATCH] st/mesa: skip draw calls with pipe_draw_info::count == 0 MIME-Version: 1.0 Content-Type: text/plain; charset=utf8 Content-Transfer-Encoding: 8bit Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=102502 Cc: 17.2 Tested-by: Alexandre Demers Tested-by: Dieter Nützel Acked-by: Timothy Arceri --- src/mesa/state_tracker/st_draw.c | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/src/mesa/state_tracker/st_draw.c b/src/mesa/state_tracker/st_draw.c index fe03a4a587e..2fe7070bcae 100644 --- a/src/mesa/state_tracker/st_draw.c +++ b/src/mesa/state_tracker/st_draw.c @@ -198,9 +198,14 @@ st_draw_vbo(struct gl_context *ctx, /* do actual drawing */ for (i = 0; i < nr_prims; i++) { + info.count = prims[i].count; + + /* Skip no-op draw calls. */ + if (!info.count && !tfb_vertcount) + continue; + info.mode = translate_prim(ctx, prims[i].mode); info.start = start + prims[i].start; - info.count = prims[i].count; info.start_instance = prims[i].base_instance; info.instance_count = prims[i].num_instances; info.index_bias = prims[i].basevertex; -- 2.30.2