2 * Mesa 3-D graphics library
5 * Copyright (C) 1999-2006 Brian Paul All Rights Reserved.
7 * Permission is hereby granted, free of charge, to any person obtaining a
8 * copy of this software and associated documentation files (the "Software"),
9 * to deal in the Software without restriction, including without limitation
10 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
11 * and/or sell copies of the Software, and to permit persons to whom the
12 * Software is furnished to do so, subject to the following conditions:
14 * The above copyright notice and this permission notice shall be included
15 * in all copies or substantial portions of the Software.
17 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
18 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
19 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
20 * BRIAN PAUL BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
21 * AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
22 * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
28 #include "bufferobj.h"
37 #define GL_BOOLEAN 0x9999
42 * Update the fields of a vertex array structure.
43 * We need to do a few special things for arrays that live in
44 * vertex buffer objects.
47 update_array(GLcontext
*ctx
, struct gl_client_array
*array
,
48 GLbitfield dirtyFlag
, GLsizei elementSize
,
49 GLint size
, GLenum type
,
50 GLsizei stride
, GLboolean normalized
, const GLvoid
*ptr
)
54 array
->Stride
= stride
;
55 array
->StrideB
= stride
? stride
: elementSize
;
56 array
->Normalized
= normalized
;
57 array
->Ptr
= (const GLubyte
*) ptr
;
58 #if FEATURE_ARB_vertex_buffer_object
59 array
->BufferObj
->RefCount
--;
60 if (array
->BufferObj
->RefCount
<= 0) {
61 ASSERT(array
->BufferObj
->Name
);
62 _mesa_remove_buffer_object( ctx
, array
->BufferObj
);
63 (*ctx
->Driver
.DeleteBuffer
)( ctx
, array
->BufferObj
);
65 array
->BufferObj
= ctx
->Array
.ArrayBufferObj
;
66 array
->BufferObj
->RefCount
++;
67 /* Compute the index of the last array element that's inside the buffer.
68 * Later in glDrawArrays we'll check if start + count > _MaxElement to
69 * be sure we won't go out of bounds.
71 if (ctx
->Array
.ArrayBufferObj
->Name
)
72 array
->_MaxElement
= ((GLsizeiptrARB
) ctx
->Array
.ArrayBufferObj
->Size
73 - (GLsizeiptrARB
) array
->Ptr
) / array
->StrideB
;
76 array
->_MaxElement
= 2 * 1000 * 1000 * 1000; /* just a big number */
78 ctx
->NewState
|= _NEW_ARRAY
;
79 ctx
->Array
.NewState
|= dirtyFlag
;
84 _mesa_VertexPointer(GLint size
, GLenum type
, GLsizei stride
, const GLvoid
*ptr
)
87 GET_CURRENT_CONTEXT(ctx
);
88 ASSERT_OUTSIDE_BEGIN_END_AND_FLUSH(ctx
);
90 if (size
< 2 || size
> 4) {
91 _mesa_error( ctx
, GL_INVALID_VALUE
, "glVertexPointer(size)" );
95 _mesa_error( ctx
, GL_INVALID_VALUE
, "glVertexPointer(stride)" );
99 if (MESA_VERBOSE
&(VERBOSE_VARRAY
|VERBOSE_API
))
100 _mesa_debug(ctx
, "glVertexPointer( sz %d type %s stride %d )\n", size
,
101 _mesa_lookup_enum_by_nr( type
), stride
);
103 /* always need to check that <type> is legal */
106 elementSize
= size
* sizeof(GLshort
);
109 elementSize
= size
* sizeof(GLint
);
112 elementSize
= size
* sizeof(GLfloat
);
115 elementSize
= size
* sizeof(GLdouble
);
118 _mesa_error( ctx
, GL_INVALID_ENUM
, "glVertexPointer(type)" );
122 update_array(ctx
, &ctx
->Array
.Vertex
, _NEW_ARRAY_VERTEX
,
123 elementSize
, size
, type
, stride
, GL_FALSE
, ptr
);
125 if (ctx
->Driver
.VertexPointer
)
126 ctx
->Driver
.VertexPointer( ctx
, size
, type
, stride
, ptr
);
131 _mesa_NormalPointer(GLenum type
, GLsizei stride
, const GLvoid
*ptr
)
134 GET_CURRENT_CONTEXT(ctx
);
135 ASSERT_OUTSIDE_BEGIN_END_AND_FLUSH(ctx
);
138 _mesa_error( ctx
, GL_INVALID_VALUE
, "glNormalPointer(stride)" );
142 if (MESA_VERBOSE
&(VERBOSE_VARRAY
|VERBOSE_API
))
143 _mesa_debug(ctx
, "glNormalPointer( type %s stride %d )\n",
144 _mesa_lookup_enum_by_nr( type
), stride
);
148 elementSize
= 3 * sizeof(GLbyte
);
151 elementSize
= 3 * sizeof(GLshort
);
154 elementSize
= 3 * sizeof(GLint
);
157 elementSize
= 3 * sizeof(GLfloat
);
160 elementSize
= 3 * sizeof(GLdouble
);
163 _mesa_error( ctx
, GL_INVALID_ENUM
, "glNormalPointer(type)" );
167 update_array(ctx
, &ctx
->Array
.Normal
, _NEW_ARRAY_NORMAL
,
168 elementSize
, 3, type
, stride
, GL_TRUE
, ptr
);
170 if (ctx
->Driver
.NormalPointer
)
171 ctx
->Driver
.NormalPointer( ctx
, type
, stride
, ptr
);
176 _mesa_ColorPointer(GLint size
, GLenum type
, GLsizei stride
, const GLvoid
*ptr
)
179 GET_CURRENT_CONTEXT(ctx
);
180 ASSERT_OUTSIDE_BEGIN_END_AND_FLUSH(ctx
);
182 if (size
< 3 || size
> 4) {
183 _mesa_error( ctx
, GL_INVALID_VALUE
, "glColorPointer(size)" );
187 _mesa_error( ctx
, GL_INVALID_VALUE
, "glColorPointer(stride)" );
191 if (MESA_VERBOSE
&(VERBOSE_VARRAY
|VERBOSE_API
))
192 _mesa_debug(ctx
, "glColorPointer( sz %d type %s stride %d )\n", size
,
193 _mesa_lookup_enum_by_nr( type
), stride
);
197 elementSize
= size
* sizeof(GLbyte
);
199 case GL_UNSIGNED_BYTE
:
200 elementSize
= size
* sizeof(GLubyte
);
203 elementSize
= size
* sizeof(GLshort
);
205 case GL_UNSIGNED_SHORT
:
206 elementSize
= size
* sizeof(GLushort
);
209 elementSize
= size
* sizeof(GLint
);
211 case GL_UNSIGNED_INT
:
212 elementSize
= size
* sizeof(GLuint
);
215 elementSize
= size
* sizeof(GLfloat
);
218 elementSize
= size
* sizeof(GLdouble
);
221 _mesa_error( ctx
, GL_INVALID_ENUM
, "glColorPointer(type)" );
225 update_array(ctx
, &ctx
->Array
.Color
, _NEW_ARRAY_COLOR0
,
226 elementSize
, size
, type
, stride
, GL_TRUE
, ptr
);
228 if (ctx
->Driver
.ColorPointer
)
229 ctx
->Driver
.ColorPointer( ctx
, size
, type
, stride
, ptr
);
234 _mesa_FogCoordPointerEXT(GLenum type
, GLsizei stride
, const GLvoid
*ptr
)
237 GET_CURRENT_CONTEXT(ctx
);
238 ASSERT_OUTSIDE_BEGIN_END_AND_FLUSH(ctx
);
241 _mesa_error( ctx
, GL_INVALID_VALUE
, "glFogCoordPointer(stride)" );
247 elementSize
= sizeof(GLfloat
);
250 elementSize
= sizeof(GLdouble
);
253 _mesa_error( ctx
, GL_INVALID_ENUM
, "glFogCoordPointer(type)" );
257 update_array(ctx
, &ctx
->Array
.FogCoord
, _NEW_ARRAY_FOGCOORD
,
258 elementSize
, 1, type
, stride
, GL_FALSE
, ptr
);
260 if (ctx
->Driver
.FogCoordPointer
)
261 ctx
->Driver
.FogCoordPointer( ctx
, type
, stride
, ptr
);
266 _mesa_IndexPointer(GLenum type
, GLsizei stride
, const GLvoid
*ptr
)
269 GET_CURRENT_CONTEXT(ctx
);
270 ASSERT_OUTSIDE_BEGIN_END_AND_FLUSH(ctx
);
273 _mesa_error( ctx
, GL_INVALID_VALUE
, "glIndexPointer(stride)" );
278 case GL_UNSIGNED_BYTE
:
279 elementSize
= sizeof(GLubyte
);
282 elementSize
= sizeof(GLshort
);
285 elementSize
= sizeof(GLint
);
288 elementSize
= sizeof(GLfloat
);
291 elementSize
= sizeof(GLdouble
);
294 _mesa_error( ctx
, GL_INVALID_ENUM
, "glIndexPointer(type)" );
298 update_array(ctx
, &ctx
->Array
.Index
, _NEW_ARRAY_INDEX
,
299 elementSize
, 1, type
, stride
, GL_FALSE
, ptr
);
301 if (ctx
->Driver
.IndexPointer
)
302 ctx
->Driver
.IndexPointer( ctx
, type
, stride
, ptr
);
307 _mesa_SecondaryColorPointerEXT(GLint size
, GLenum type
,
308 GLsizei stride
, const GLvoid
*ptr
)
311 GET_CURRENT_CONTEXT(ctx
);
312 ASSERT_OUTSIDE_BEGIN_END_AND_FLUSH(ctx
);
314 if (size
!= 3 && size
!= 4) {
315 _mesa_error( ctx
, GL_INVALID_VALUE
, "glSecondaryColorPointer(size)" );
319 _mesa_error( ctx
, GL_INVALID_VALUE
, "glSecondaryColorPointer(stride)" );
323 if (MESA_VERBOSE
&(VERBOSE_VARRAY
|VERBOSE_API
))
324 _mesa_debug(ctx
, "glSecondaryColorPointer( sz %d type %s stride %d )\n",
325 size
, _mesa_lookup_enum_by_nr( type
), stride
);
329 elementSize
= size
* sizeof(GLbyte
);
331 case GL_UNSIGNED_BYTE
:
332 elementSize
= size
* sizeof(GLubyte
);
335 elementSize
= size
* sizeof(GLshort
);
337 case GL_UNSIGNED_SHORT
:
338 elementSize
= size
* sizeof(GLushort
);
341 elementSize
= size
* sizeof(GLint
);
343 case GL_UNSIGNED_INT
:
344 elementSize
= size
* sizeof(GLuint
);
347 elementSize
= size
* sizeof(GLfloat
);
350 elementSize
= size
* sizeof(GLdouble
);
353 _mesa_error( ctx
, GL_INVALID_ENUM
, "glSecondaryColorPointer(type)" );
357 update_array(ctx
, &ctx
->Array
.SecondaryColor
, _NEW_ARRAY_COLOR1
,
358 elementSize
, size
, type
, stride
, GL_TRUE
, ptr
);
360 if (ctx
->Driver
.SecondaryColorPointer
)
361 ctx
->Driver
.SecondaryColorPointer( ctx
, size
, type
, stride
, ptr
);
366 _mesa_TexCoordPointer(GLint size
, GLenum type
, GLsizei stride
,
370 GET_CURRENT_CONTEXT(ctx
);
371 const GLuint unit
= ctx
->Array
.ActiveTexture
;
372 ASSERT_OUTSIDE_BEGIN_END_AND_FLUSH(ctx
);
374 if (size
< 1 || size
> 4) {
375 _mesa_error( ctx
, GL_INVALID_VALUE
, "glTexCoordPointer(size)" );
379 _mesa_error( ctx
, GL_INVALID_VALUE
, "glTexCoordPointer(stride)" );
383 if (MESA_VERBOSE
&(VERBOSE_VARRAY
|VERBOSE_API
))
384 _mesa_debug(ctx
, "glTexCoordPointer(unit %u sz %d type %s stride %d)\n",
385 unit
, size
, _mesa_lookup_enum_by_nr( type
), stride
);
387 /* always need to check that <type> is legal */
390 elementSize
= size
* sizeof(GLshort
);
393 elementSize
= size
* sizeof(GLint
);
396 elementSize
= size
* sizeof(GLfloat
);
399 elementSize
= size
* sizeof(GLdouble
);
402 _mesa_error( ctx
, GL_INVALID_ENUM
, "glTexCoordPointer(type)" );
406 update_array(ctx
, &ctx
->Array
.TexCoord
[unit
], _NEW_ARRAY_TEXCOORD(unit
),
407 elementSize
, size
, type
, stride
, GL_FALSE
, ptr
);
409 if (ctx
->Driver
.TexCoordPointer
)
410 ctx
->Driver
.TexCoordPointer( ctx
, size
, type
, stride
, ptr
);
415 _mesa_EdgeFlagPointer(GLsizei stride
, const GLvoid
*ptr
)
417 GET_CURRENT_CONTEXT(ctx
);
418 ASSERT_OUTSIDE_BEGIN_END_AND_FLUSH(ctx
);
421 _mesa_error( ctx
, GL_INVALID_VALUE
, "glEdgeFlagPointer(stride)" );
425 update_array(ctx
, &ctx
->Array
.EdgeFlag
, _NEW_ARRAY_EDGEFLAG
,
426 sizeof(GLboolean
), 1, GL_BOOLEAN
, stride
, GL_FALSE
, ptr
);
428 if (ctx
->Driver
.EdgeFlagPointer
)
429 ctx
->Driver
.EdgeFlagPointer( ctx
, stride
, ptr
);
433 #if FEATURE_NV_vertex_program
435 _mesa_VertexAttribPointerNV(GLuint index
, GLint size
, GLenum type
,
436 GLsizei stride
, const GLvoid
*ptr
)
438 const GLboolean normalized
= GL_FALSE
;
440 GET_CURRENT_CONTEXT(ctx
);
441 ASSERT_OUTSIDE_BEGIN_END(ctx
);
443 if (index
>= MAX_VERTEX_PROGRAM_ATTRIBS
) {
444 _mesa_error(ctx
, GL_INVALID_VALUE
, "glVertexAttribPointerNV(index)");
448 if (size
< 1 || size
> 4) {
449 _mesa_error(ctx
, GL_INVALID_VALUE
, "glVertexAttribPointerNV(size)");
454 _mesa_error(ctx
, GL_INVALID_VALUE
, "glVertexAttribPointerNV(stride)");
458 if (type
== GL_UNSIGNED_BYTE
&& size
!= 4) {
459 _mesa_error(ctx
, GL_INVALID_VALUE
, "glVertexAttribPointerNV(size!=4)");
463 /* check for valid 'type' and compute StrideB right away */
465 case GL_UNSIGNED_BYTE
:
466 elementSize
= size
* sizeof(GLubyte
);
469 elementSize
= size
* sizeof(GLshort
);
472 elementSize
= size
* sizeof(GLfloat
);
475 elementSize
= size
* sizeof(GLdouble
);
478 _mesa_error( ctx
, GL_INVALID_ENUM
, "glVertexAttribPointerNV(type)" );
482 update_array(ctx
, &ctx
->Array
.VertexAttrib
[index
], _NEW_ARRAY_ATTRIB(index
),
483 elementSize
, size
, type
, stride
, normalized
, ptr
);
485 if (ctx
->Driver
.VertexAttribPointer
)
486 ctx
->Driver
.VertexAttribPointer( ctx
, index
, size
, type
, stride
, ptr
);
491 #if FEATURE_ARB_vertex_program
493 _mesa_VertexAttribPointerARB(GLuint index
, GLint size
, GLenum type
,
494 GLboolean normalized
,
495 GLsizei stride
, const GLvoid
*ptr
)
498 GET_CURRENT_CONTEXT(ctx
);
499 ASSERT_OUTSIDE_BEGIN_END(ctx
);
501 if (index
>= ctx
->Const
.VertexProgram
.MaxAttribs
) {
502 _mesa_error(ctx
, GL_INVALID_VALUE
, "glVertexAttribPointerARB(index)");
506 if (size
< 1 || size
> 4) {
507 _mesa_error(ctx
, GL_INVALID_VALUE
, "glVertexAttribPointerARB(size)");
512 _mesa_error(ctx
, GL_INVALID_VALUE
, "glVertexAttribPointerARB(stride)");
516 if (type
== GL_UNSIGNED_BYTE
&& size
!= 4) {
517 _mesa_error(ctx
, GL_INVALID_VALUE
, "glVertexAttribPointerARB(size!=4)");
521 /* check for valid 'type' and compute StrideB right away */
522 /* NOTE: more types are supported here than in the NV extension */
525 elementSize
= size
* sizeof(GLbyte
);
527 case GL_UNSIGNED_BYTE
:
528 elementSize
= size
* sizeof(GLubyte
);
531 elementSize
= size
* sizeof(GLshort
);
533 case GL_UNSIGNED_SHORT
:
534 elementSize
= size
* sizeof(GLushort
);
537 elementSize
= size
* sizeof(GLint
);
539 case GL_UNSIGNED_INT
:
540 elementSize
= size
* sizeof(GLuint
);
543 elementSize
= size
* sizeof(GLfloat
);
546 elementSize
= size
* sizeof(GLdouble
);
549 _mesa_error( ctx
, GL_INVALID_ENUM
, "glVertexAttribPointerARB(type)" );
553 update_array(ctx
, &ctx
->Array
.VertexAttrib
[index
], _NEW_ARRAY_ATTRIB(index
),
554 elementSize
, size
, type
, stride
, normalized
, ptr
);
557 if (ctx->Driver.VertexAttribPointer)
558 ctx->Driver.VertexAttribPointer( ctx, index, size, type, stride, ptr );
565 _mesa_VertexPointerEXT(GLint size
, GLenum type
, GLsizei stride
,
566 GLsizei count
, const GLvoid
*ptr
)
569 _mesa_VertexPointer(size
, type
, stride
, ptr
);
574 _mesa_NormalPointerEXT(GLenum type
, GLsizei stride
, GLsizei count
,
578 _mesa_NormalPointer(type
, stride
, ptr
);
583 _mesa_ColorPointerEXT(GLint size
, GLenum type
, GLsizei stride
, GLsizei count
,
587 _mesa_ColorPointer(size
, type
, stride
, ptr
);
592 _mesa_IndexPointerEXT(GLenum type
, GLsizei stride
, GLsizei count
,
596 _mesa_IndexPointer(type
, stride
, ptr
);
601 _mesa_TexCoordPointerEXT(GLint size
, GLenum type
, GLsizei stride
,
602 GLsizei count
, const GLvoid
*ptr
)
605 _mesa_TexCoordPointer(size
, type
, stride
, ptr
);
610 _mesa_EdgeFlagPointerEXT(GLsizei stride
, GLsizei count
, const GLboolean
*ptr
)
613 _mesa_EdgeFlagPointer(stride
, ptr
);
618 _mesa_InterleavedArrays(GLenum format
, GLsizei stride
, const GLvoid
*pointer
)
620 GET_CURRENT_CONTEXT(ctx
);
621 GLboolean tflag
, cflag
, nflag
; /* enable/disable flags */
622 GLint tcomps
, ccomps
, vcomps
; /* components per texcoord, color, vertex */
623 GLenum ctype
= 0; /* color type */
624 GLint coffset
= 0, noffset
= 0, voffset
;/* color, normal, vertex offsets */
625 const GLint toffset
= 0; /* always zero */
626 GLint defstride
; /* default stride */
629 ASSERT_OUTSIDE_BEGIN_END_AND_FLUSH(ctx
);
632 c
= f
* ((4 * sizeof(GLubyte
) + (f
- 1)) / f
);
635 _mesa_error( ctx
, GL_INVALID_VALUE
, "glInterleavedArrays(stride)" );
641 tflag
= GL_FALSE
; cflag
= GL_FALSE
; nflag
= GL_FALSE
;
642 tcomps
= 0; ccomps
= 0; vcomps
= 2;
647 tflag
= GL_FALSE
; cflag
= GL_FALSE
; nflag
= GL_FALSE
;
648 tcomps
= 0; ccomps
= 0; vcomps
= 3;
653 tflag
= GL_FALSE
; cflag
= GL_TRUE
; nflag
= GL_FALSE
;
654 tcomps
= 0; ccomps
= 4; vcomps
= 2;
655 ctype
= GL_UNSIGNED_BYTE
;
661 tflag
= GL_FALSE
; cflag
= GL_TRUE
; nflag
= GL_FALSE
;
662 tcomps
= 0; ccomps
= 4; vcomps
= 3;
663 ctype
= GL_UNSIGNED_BYTE
;
669 tflag
= GL_FALSE
; cflag
= GL_TRUE
; nflag
= GL_FALSE
;
670 tcomps
= 0; ccomps
= 3; vcomps
= 3;
677 tflag
= GL_FALSE
; cflag
= GL_FALSE
; nflag
= GL_TRUE
;
678 tcomps
= 0; ccomps
= 0; vcomps
= 3;
684 tflag
= GL_FALSE
; cflag
= GL_TRUE
; nflag
= GL_TRUE
;
685 tcomps
= 0; ccomps
= 4; vcomps
= 3;
693 tflag
= GL_TRUE
; cflag
= GL_FALSE
; nflag
= GL_FALSE
;
694 tcomps
= 2; ccomps
= 0; vcomps
= 3;
699 tflag
= GL_TRUE
; cflag
= GL_FALSE
; nflag
= GL_FALSE
;
700 tcomps
= 4; ccomps
= 0; vcomps
= 4;
704 case GL_T2F_C4UB_V3F
:
705 tflag
= GL_TRUE
; cflag
= GL_TRUE
; nflag
= GL_FALSE
;
706 tcomps
= 2; ccomps
= 4; vcomps
= 3;
707 ctype
= GL_UNSIGNED_BYTE
;
713 tflag
= GL_TRUE
; cflag
= GL_TRUE
; nflag
= GL_FALSE
;
714 tcomps
= 2; ccomps
= 3; vcomps
= 3;
721 tflag
= GL_TRUE
; cflag
= GL_FALSE
; nflag
= GL_TRUE
;
722 tcomps
= 2; ccomps
= 0; vcomps
= 3;
727 case GL_T2F_C4F_N3F_V3F
:
728 tflag
= GL_TRUE
; cflag
= GL_TRUE
; nflag
= GL_TRUE
;
729 tcomps
= 2; ccomps
= 4; vcomps
= 3;
736 case GL_T4F_C4F_N3F_V4F
:
737 tflag
= GL_TRUE
; cflag
= GL_TRUE
; nflag
= GL_TRUE
;
738 tcomps
= 4; ccomps
= 4; vcomps
= 4;
746 _mesa_error( ctx
, GL_INVALID_ENUM
, "glInterleavedArrays(format)" );
754 _mesa_DisableClientState( GL_EDGE_FLAG_ARRAY
);
755 _mesa_DisableClientState( GL_INDEX_ARRAY
);
756 /* XXX also disable secondary color and generic arrays? */
760 _mesa_EnableClientState( GL_TEXTURE_COORD_ARRAY
);
761 _mesa_TexCoordPointer( tcomps
, GL_FLOAT
, stride
,
762 (GLubyte
*) pointer
+ toffset
);
765 _mesa_DisableClientState( GL_TEXTURE_COORD_ARRAY
);
770 _mesa_EnableClientState( GL_COLOR_ARRAY
);
771 _mesa_ColorPointer( ccomps
, ctype
, stride
,
772 (GLubyte
*) pointer
+ coffset
);
775 _mesa_DisableClientState( GL_COLOR_ARRAY
);
781 _mesa_EnableClientState( GL_NORMAL_ARRAY
);
782 _mesa_NormalPointer( GL_FLOAT
, stride
, (GLubyte
*) pointer
+ noffset
);
785 _mesa_DisableClientState( GL_NORMAL_ARRAY
);
789 _mesa_EnableClientState( GL_VERTEX_ARRAY
);
790 _mesa_VertexPointer( vcomps
, GL_FLOAT
, stride
,
791 (GLubyte
*) pointer
+ voffset
);
796 _mesa_LockArraysEXT(GLint first
, GLsizei count
)
798 GET_CURRENT_CONTEXT(ctx
);
799 ASSERT_OUTSIDE_BEGIN_END_AND_FLUSH(ctx
);
801 if (MESA_VERBOSE
& VERBOSE_API
)
802 _mesa_debug(ctx
, "glLockArrays %d %d\n", first
, count
);
804 if (first
== 0 && count
> 0 &&
805 count
<= (GLint
) ctx
->Const
.MaxArrayLockSize
) {
806 ctx
->Array
.LockFirst
= first
;
807 ctx
->Array
.LockCount
= count
;
810 ctx
->Array
.LockFirst
= 0;
811 ctx
->Array
.LockCount
= 0;
814 ctx
->NewState
|= _NEW_ARRAY
;
815 ctx
->Array
.NewState
|= _NEW_ARRAY_ALL
;
817 if (ctx
->Driver
.LockArraysEXT
)
818 ctx
->Driver
.LockArraysEXT( ctx
, first
, count
);
823 _mesa_UnlockArraysEXT( void )
825 GET_CURRENT_CONTEXT(ctx
);
826 ASSERT_OUTSIDE_BEGIN_END_AND_FLUSH(ctx
);
828 if (MESA_VERBOSE
& VERBOSE_API
)
829 _mesa_debug(ctx
, "glUnlockArrays\n");
831 ctx
->Array
.LockFirst
= 0;
832 ctx
->Array
.LockCount
= 0;
833 ctx
->NewState
|= _NEW_ARRAY
;
834 ctx
->Array
.NewState
|= _NEW_ARRAY_ALL
;
836 if (ctx
->Driver
.UnlockArraysEXT
)
837 ctx
->Driver
.UnlockArraysEXT( ctx
);
841 /* GL_EXT_multi_draw_arrays */
842 /* Somebody forgot to spec the first and count parameters as const! <sigh> */
844 _mesa_MultiDrawArraysEXT( GLenum mode
, GLint
*first
,
845 GLsizei
*count
, GLsizei primcount
)
847 GET_CURRENT_CONTEXT(ctx
);
850 ASSERT_OUTSIDE_BEGIN_END_AND_FLUSH(ctx
);
852 for (i
= 0; i
< primcount
; i
++) {
854 CALL_DrawArrays(ctx
->Exec
, (mode
, first
[i
], count
[i
]));
860 /* GL_EXT_multi_draw_arrays */
862 _mesa_MultiDrawElementsEXT( GLenum mode
, const GLsizei
*count
, GLenum type
,
863 const GLvoid
**indices
, GLsizei primcount
)
865 GET_CURRENT_CONTEXT(ctx
);
868 ASSERT_OUTSIDE_BEGIN_END_AND_FLUSH(ctx
);
870 for (i
= 0; i
< primcount
; i
++) {
872 CALL_DrawElements(ctx
->Exec
, (mode
, count
[i
], type
, indices
[i
]));
878 /* GL_IBM_multimode_draw_arrays */
880 _mesa_MultiModeDrawArraysIBM( const GLenum
* mode
, const GLint
* first
,
881 const GLsizei
* count
,
882 GLsizei primcount
, GLint modestride
)
884 GET_CURRENT_CONTEXT(ctx
);
887 ASSERT_OUTSIDE_BEGIN_END_AND_FLUSH(ctx
);
889 for ( i
= 0 ; i
< primcount
; i
++ ) {
890 if ( count
[i
] > 0 ) {
891 GLenum m
= *((GLenum
*) ((GLubyte
*) mode
+ i
* modestride
));
892 CALL_DrawArrays(ctx
->Exec
, ( m
, first
[i
], count
[i
] ));
898 /* GL_IBM_multimode_draw_arrays */
900 _mesa_MultiModeDrawElementsIBM( const GLenum
* mode
, const GLsizei
* count
,
901 GLenum type
, const GLvoid
* const * indices
,
902 GLsizei primcount
, GLint modestride
)
904 GET_CURRENT_CONTEXT(ctx
);
907 ASSERT_OUTSIDE_BEGIN_END_AND_FLUSH(ctx
);
909 /* XXX not sure about ARB_vertex_buffer_object handling here */
911 for ( i
= 0 ; i
< primcount
; i
++ ) {
912 if ( count
[i
] > 0 ) {
913 GLenum m
= *((GLenum
*) ((GLubyte
*) mode
+ i
* modestride
));
914 CALL_DrawElements(ctx
->Exec
, ( m
, count
[i
], type
, indices
[i
] ));
921 * Initialize vertex array state for given context.
924 _mesa_init_varray(GLcontext
*ctx
)
929 ctx
->Array
.Vertex
.Size
= 4;
930 ctx
->Array
.Vertex
.Type
= GL_FLOAT
;
931 ctx
->Array
.Vertex
.Stride
= 0;
932 ctx
->Array
.Vertex
.StrideB
= 0;
933 ctx
->Array
.Vertex
.Ptr
= NULL
;
934 ctx
->Array
.Vertex
.Enabled
= GL_FALSE
;
935 ctx
->Array
.Vertex
.Flags
= CA_CLIENT_DATA
;
936 ctx
->Array
.Normal
.Type
= GL_FLOAT
;
937 ctx
->Array
.Normal
.Stride
= 0;
938 ctx
->Array
.Normal
.StrideB
= 0;
939 ctx
->Array
.Normal
.Ptr
= NULL
;
940 ctx
->Array
.Normal
.Enabled
= GL_FALSE
;
941 ctx
->Array
.Normal
.Flags
= CA_CLIENT_DATA
;
942 ctx
->Array
.Color
.Size
= 4;
943 ctx
->Array
.Color
.Type
= GL_FLOAT
;
944 ctx
->Array
.Color
.Stride
= 0;
945 ctx
->Array
.Color
.StrideB
= 0;
946 ctx
->Array
.Color
.Ptr
= NULL
;
947 ctx
->Array
.Color
.Enabled
= GL_FALSE
;
948 ctx
->Array
.Color
.Flags
= CA_CLIENT_DATA
;
949 ctx
->Array
.SecondaryColor
.Size
= 4;
950 ctx
->Array
.SecondaryColor
.Type
= GL_FLOAT
;
951 ctx
->Array
.SecondaryColor
.Stride
= 0;
952 ctx
->Array
.SecondaryColor
.StrideB
= 0;
953 ctx
->Array
.SecondaryColor
.Ptr
= NULL
;
954 ctx
->Array
.SecondaryColor
.Enabled
= GL_FALSE
;
955 ctx
->Array
.SecondaryColor
.Flags
= CA_CLIENT_DATA
;
956 ctx
->Array
.FogCoord
.Size
= 1;
957 ctx
->Array
.FogCoord
.Type
= GL_FLOAT
;
958 ctx
->Array
.FogCoord
.Stride
= 0;
959 ctx
->Array
.FogCoord
.StrideB
= 0;
960 ctx
->Array
.FogCoord
.Ptr
= NULL
;
961 ctx
->Array
.FogCoord
.Enabled
= GL_FALSE
;
962 ctx
->Array
.FogCoord
.Flags
= CA_CLIENT_DATA
;
963 ctx
->Array
.Index
.Type
= GL_FLOAT
;
964 ctx
->Array
.Index
.Stride
= 0;
965 ctx
->Array
.Index
.StrideB
= 0;
966 ctx
->Array
.Index
.Ptr
= NULL
;
967 ctx
->Array
.Index
.Enabled
= GL_FALSE
;
968 ctx
->Array
.Index
.Flags
= CA_CLIENT_DATA
;
969 for (i
= 0; i
< MAX_TEXTURE_UNITS
; i
++) {
970 ctx
->Array
.TexCoord
[i
].Size
= 4;
971 ctx
->Array
.TexCoord
[i
].Type
= GL_FLOAT
;
972 ctx
->Array
.TexCoord
[i
].Stride
= 0;
973 ctx
->Array
.TexCoord
[i
].StrideB
= 0;
974 ctx
->Array
.TexCoord
[i
].Ptr
= NULL
;
975 ctx
->Array
.TexCoord
[i
].Enabled
= GL_FALSE
;
976 ctx
->Array
.TexCoord
[i
].Flags
= CA_CLIENT_DATA
;
978 ctx
->Array
.EdgeFlag
.Stride
= 0;
979 ctx
->Array
.EdgeFlag
.StrideB
= 0;
980 ctx
->Array
.EdgeFlag
.Ptr
= NULL
;
981 ctx
->Array
.EdgeFlag
.Enabled
= GL_FALSE
;
982 ctx
->Array
.EdgeFlag
.Flags
= CA_CLIENT_DATA
;
983 for (i
= 0; i
< VERT_ATTRIB_MAX
; i
++) {
984 ctx
->Array
.VertexAttrib
[i
].Size
= 4;
985 ctx
->Array
.VertexAttrib
[i
].Type
= GL_FLOAT
;
986 ctx
->Array
.VertexAttrib
[i
].Stride
= 0;
987 ctx
->Array
.VertexAttrib
[i
].StrideB
= 0;
988 ctx
->Array
.VertexAttrib
[i
].Ptr
= NULL
;
989 ctx
->Array
.VertexAttrib
[i
].Enabled
= GL_FALSE
;
990 ctx
->Array
.VertexAttrib
[i
].Normalized
= GL_FALSE
;
991 ctx
->Array
.VertexAttrib
[i
].Flags
= CA_CLIENT_DATA
;
994 ctx
->Array
.ActiveTexture
= 0; /* GL_ARB_multitexture */