summaryrefslogtreecommitdiffstats
path: root/src/gallium/auxiliary/draw/draw_pt.c
diff options
context:
space:
mode:
authorBrian Paul <[email protected]>2011-11-12 11:50:32 -0700
committerBrian Paul <[email protected]>2011-11-15 07:49:26 -0700
commit438d7ac146dc89d1c2943610c662c57e11a47382 (patch)
tree4012cac294434d0238323f80e479f98d832fe41a /src/gallium/auxiliary/draw/draw_pt.c
parent94780b5ee6dc118e22c29b5543c4db8e0ab1f393 (diff)
util/draw: replace assertions with conditionals in util_draw_max_index()
Don't assert/die if a VBO is too small. Return zero instead. For debug builds, emit a warning message since this is an unusual situation that might indicate that there's a bug in the app. Note that util_draw_max_index() now returns max_index+1 instead of max_index. This lets us return zero to indicate that one of the VBOs is too small to draw anything. Fixes a failure with the new piglit vbo-too-small test. Reviewed-by: José Fonseca <[email protected]>
Diffstat (limited to 'src/gallium/auxiliary/draw/draw_pt.c')
-rw-r--r--src/gallium/auxiliary/draw/draw_pt.c20
1 files changed, 15 insertions, 5 deletions
diff --git a/src/gallium/auxiliary/draw/draw_pt.c b/src/gallium/auxiliary/draw/draw_pt.c
index e0eda67c1a2..080e03dd46f 100644
--- a/src/gallium/auxiliary/draw/draw_pt.c
+++ b/src/gallium/auxiliary/draw/draw_pt.c
@@ -422,6 +422,7 @@ draw_vbo(struct draw_context *draw,
{
unsigned reduced_prim = u_reduced_prim(info->mode);
unsigned instance;
+ unsigned index_limit;
assert(info->instance_count > 0);
if (info->indexed)
@@ -470,11 +471,20 @@ draw_vbo(struct draw_context *draw,
if (0)
draw_print_arrays(draw, info->mode, info->start, MIN2(info->count, 20));
- draw->pt.max_index = util_draw_max_index(draw->pt.vertex_buffer,
- draw->pt.nr_vertex_buffers,
- draw->pt.vertex_element,
- draw->pt.nr_vertex_elements,
- info);
+ index_limit = util_draw_max_index(draw->pt.vertex_buffer,
+ draw->pt.nr_vertex_buffers,
+ draw->pt.vertex_element,
+ draw->pt.nr_vertex_elements,
+ info);
+
+ if (index_limit == 0) {
+ /* one of the buffers is too small to do any valid drawing */
+ debug_warning("draw: VBO too small to draw anything\n");
+ return;
+ }
+
+ draw->pt.max_index = index_limit - 1;
+
/*
* TODO: We could use draw->pt.max_index to further narrow