diff options
author | Marek Olšák <[email protected]> | 2010-06-05 19:32:29 +0200 |
---|---|---|
committer | Brian Paul <[email protected]> | 2010-07-20 11:53:43 -0600 |
commit | 5ed6627ceb82845a7b578419b3cd4168ad0106d3 (patch) | |
tree | f0a197d8ab531e2fffff51f05b7d82e6693a4fe7 | |
parent | 691c1fb074144395aa441b3102923d8f92136c37 (diff) |
st/mesa: implement and advertise GL_ARB_draw_elements_base_vertex
Signed-off-by: Brian Paul <[email protected]>
-rw-r--r-- | src/mesa/state_tracker/st_draw.c | 7 | ||||
-rw-r--r-- | src/mesa/state_tracker/st_extensions.c | 1 |
2 files changed, 5 insertions, 3 deletions
diff --git a/src/mesa/state_tracker/st_draw.c b/src/mesa/state_tracker/st_draw.c index 7fdaff45f76..5821da4889d 100644 --- a/src/mesa/state_tracker/st_draw.c +++ b/src/mesa/state_tracker/st_draw.c @@ -695,7 +695,8 @@ st_draw_vbo(GLcontext *ctx, unsigned prim = translate_prim(ctx, prims[i].mode); if (u_trim_pipe_prim(prims[i].mode, &vcount)) { - pipe->draw_range_elements(pipe, indexBuf, indexSize, 0, + pipe->draw_range_elements(pipe, indexBuf, indexSize, + prims[i].basevertex, min_index, max_index, prim, prims[i].start + indexOffset, vcount); } @@ -710,7 +711,7 @@ st_draw_vbo(GLcontext *ctx, if (prims[i].num_instances == 1) { pipe->draw_elements(pipe, indexBuf, indexSize, - 0, /* indexBias */ + prims[i].basevertex, prim, prims[i].start + indexOffset, vcount); @@ -718,7 +719,7 @@ st_draw_vbo(GLcontext *ctx, else { pipe->draw_elements_instanced(pipe, indexBuf, indexSize, - 0, /* indexBias */ + prims[i].basevertex, prim, prims[i].start + indexOffset, vcount, diff --git a/src/mesa/state_tracker/st_extensions.c b/src/mesa/state_tracker/st_extensions.c index c5326fe0db0..d23ac0c2845 100644 --- a/src/mesa/state_tracker/st_extensions.c +++ b/src/mesa/state_tracker/st_extensions.c @@ -180,6 +180,7 @@ void st_init_extensions(struct st_context *st) * Extensions that are supported by all Gallium drivers: */ ctx->Extensions.ARB_copy_buffer = GL_TRUE; + ctx->Extensions.ARB_draw_elements_base_vertex = GL_TRUE; ctx->Extensions.ARB_fragment_coord_conventions = GL_TRUE; ctx->Extensions.ARB_fragment_program = GL_TRUE; ctx->Extensions.ARB_map_buffer_range = GL_TRUE; |