diff options
author | Francisco Jerez <[email protected]> | 2010-03-07 19:12:27 +0100 |
---|---|---|
committer | Francisco Jerez <[email protected]> | 2010-03-07 22:40:11 +0100 |
commit | ea027bda8e4a7cdd8f131e01ab4ff80d6c6a3ab7 (patch) | |
tree | 8fd5d427fe9153fb930df319f5fb20c0b04089aa /src/mesa | |
parent | 75f52d1e5210944d7e92787c637285fd83533053 (diff) |
dri/nouveau: Split big client buffers in the indexed case too.
Diffstat (limited to 'src/mesa')
-rw-r--r-- | src/mesa/drivers/dri/nouveau/nouveau_vbo_t.c | 7 |
1 files changed, 3 insertions, 4 deletions
diff --git a/src/mesa/drivers/dri/nouveau/nouveau_vbo_t.c b/src/mesa/drivers/dri/nouveau/nouveau_vbo_t.c index 69a9b96f0ca..a365b977f29 100644 --- a/src/mesa/drivers/dri/nouveau/nouveau_vbo_t.c +++ b/src/mesa/drivers/dri/nouveau/nouveau_vbo_t.c @@ -281,14 +281,13 @@ vbo_maybe_split(GLcontext *ctx, const struct gl_client_array **arrays, int stride; /* Try to keep client buffers smaller than the scratch BOs. */ - if (!ib && render->mode == VBO && + if (render->mode == VBO && (stride = get_max_client_stride(ctx))) vert_avail = MIN2(vert_avail, RENDER_SCRATCH_SIZE / stride); - - if ((ib && ib->count > idx_avail) || - (!ib && max_index - min_index > vert_avail)) { + if (max_index - min_index > vert_avail || + (ib && ib->count > idx_avail)) { struct split_limits limits = { .max_verts = vert_avail, .max_indices = idx_avail, |