diff options
author | Chia-I Wu <olv@lunarg.com> | 2010-08-07 00:50:32 +0800 |
---|---|---|
committer | Chia-I Wu <olv@lunarg.com> | 2010-08-07 02:20:06 +0800 |
commit | e34c52da87990b1ec64602a20418cdb274deefa9 (patch) | |
tree | 91a48dd713473197b5f8da0f31cc9c80bf9d844c | |
parent | 600cd858d446bc1698a9b28f714f3fd6145316fb (diff) |
draw: Add an assertion to varray's version of trim().
Assert that "first" is always smaller than "count" and add reasoning.
It would be better to simply fix trim(), but it is used in tight loops
right now.
-rw-r--r-- | src/gallium/auxiliary/draw/draw_pt_varray_tmp_linear.h | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/src/gallium/auxiliary/draw/draw_pt_varray_tmp_linear.h b/src/gallium/auxiliary/draw/draw_pt_varray_tmp_linear.h index a292346be9..55e43b2a71 100644 --- a/src/gallium/auxiliary/draw/draw_pt_varray_tmp_linear.h +++ b/src/gallium/auxiliary/draw/draw_pt_varray_tmp_linear.h @@ -1,6 +1,11 @@ static unsigned trim( unsigned count, unsigned first, unsigned incr ) { - return count - (count - first) % incr; + /* + * count either has been trimmed in draw_pt_arrays or is set to + * (driver)_fetch_max which is hopefully always larger than first. + */ + assert(count >= first); + return count - (count - first) % incr; } static void FUNC(struct draw_pt_front_end *frontend, |