summaryrefslogtreecommitdiff
path: root/src/mesa/state_tracker/st_draw.c
diff options
context:
space:
mode:
authorBen Skeggs <skeggsb@gmail.com>2007-12-10 21:09:52 +1100
committerBen Skeggs <skeggsb@gmail.com>2007-12-10 21:09:52 +1100
commit18fe9776b4977af092582630b181893b2bc6de40 (patch)
tree1de97fc646272c47d0aad8bc483618f527ac0ab5 /src/mesa/state_tracker/st_draw.c
parentaab6f8f9485e73eb4098e7c4b497da5c30f1cf06 (diff)
parentf7195b32323d50e9541a5c5cb3143e83d05bd8d8 (diff)
Merge branch 'upstream-gallium-0.1' into darktama-gallium-0.1
Diffstat (limited to 'src/mesa/state_tracker/st_draw.c')
-rw-r--r--src/mesa/state_tracker/st_draw.c11
1 files changed, 8 insertions, 3 deletions
diff --git a/src/mesa/state_tracker/st_draw.c b/src/mesa/state_tracker/st_draw.c
index c6fea1f7bc..24bb4823bc 100644
--- a/src/mesa/state_tracker/st_draw.c
+++ b/src/mesa/state_tracker/st_draw.c
@@ -266,9 +266,14 @@ st_draw_vbo(GLcontext *ctx,
}
else {
/* attribute data is in user-space memory, not a VBO */
- uint bytes = (arrays[mesaAttr]->Size
- * _mesa_sizeof_type(arrays[mesaAttr]->Type)
- * (max_index + 1));
+ uint bytes;
+
+ if (!arrays[mesaAttr]->StrideB) {
+ bytes = arrays[mesaAttr]->Size
+ * _mesa_sizeof_type(arrays[mesaAttr]->Type);
+ } else {
+ bytes = arrays[mesaAttr]->StrideB * (max_index + 1);
+ }
/* wrap user data */
vbuffer[attr].buffer