diff options
| author | Marek Olšák <maraeo@gmail.com> | 2010-12-11 14:45:27 +0100 | 
|---|---|---|
| committer | Marek Olšák <maraeo@gmail.com> | 2010-12-11 14:49:28 +0100 | 
| commit | 2af8a1983180fc0168c1e0e53bcc69ee3d684ea4 (patch) | |
| tree | 098f7104ce099101a073f04078a6d7666f7d4d5d /src/gallium/drivers | |
| parent | c398f1544ea113279e5f038f4a643005743cab62 (diff) | |
r300g: fix rendering with a vertex attrib having a zero stride
The hardware apparently does support a zero stride, so let's use it.
This fixes missing objects in ETQW, but might also fix a ton of other
similar-looking bugs.
NOTE: This is a candidate for both the 7.9 and 7.10 branches.
Diffstat (limited to 'src/gallium/drivers')
| -rw-r--r-- | src/gallium/drivers/r300/r300_state.c | 14 | 
1 files changed, 7 insertions, 7 deletions
| diff --git a/src/gallium/drivers/r300/r300_state.c b/src/gallium/drivers/r300/r300_state.c index 7529253240..0ad8a1f420 100644 --- a/src/gallium/drivers/r300/r300_state.c +++ b/src/gallium/drivers/r300/r300_state.c @@ -1496,14 +1496,14 @@ static void r300_set_vertex_buffers(struct pipe_context* pipe,                  any_user_buffer = TRUE;              } +            /* The stride of zero means we will be fetching only the first +             * vertex, so don't care about max_index. */ +            if (!vbo->stride) +                continue; +              if (vbo->max_index == ~0) { -                /* if no VBO stride then only one vertex value so max index is 1 */ -                /* should think about converting to VS constants like svga does */ -                if (!vbo->stride) -                    vbo->max_index = 1; -                else -                    vbo->max_index = -                             (vbo->buffer->width0 - vbo->buffer_offset) / vbo->stride; +                vbo->max_index = +                        (vbo->buffer->width0 - vbo->buffer_offset) / vbo->stride;              }              max_index = MIN2(vbo->max_index, max_index); | 
