/* Copyright (c) 2001, Stanford University * All rights reserved * * See the file LICENSE.txt for information on redistributing this software. */ /* * Packer functions for GL_NV_vertex_program extension. * XXX: Quite a few of these functions are unfinished. */ #include "packer.h" #include "cr_error.h" void PACK_APIENTRY crPackProgramParameters4dvNV(GLenum target, GLuint index, GLuint num, const GLdouble * params) { CR_GET_PACKER_CONTEXT(pc); unsigned char *data_ptr = NULL; int packet_length = sizeof(int) + sizeof(target) + sizeof(index) + sizeof(num) + num * 4 * sizeof(GLdouble); CR_GET_BUFFERED_POINTER(pc, packet_length); WRITE_DATA(0, int, packet_length); WRITE_DATA(sizeof(int) + 0, GLenum, target); WRITE_DATA(sizeof(int) + 4, GLuint, index); WRITE_DATA(sizeof(int) + 8, GLuint, num); crMemcpy(data_ptr + sizeof(int) + 12, params, num * 4 * sizeof(GLdouble)); WRITE_OPCODE(pc, CR_PROGRAMPARAMETERS4DVNV_EXTEND_OPCODE); CR_UNLOCK_PACKER_CONTEXT(pc); } void PACK_APIENTRY crPackProgramParameters4fvNV(GLenum target, GLuint index, GLuint num, const GLfloat * params) { CR_GET_PACKER_CONTEXT(pc); unsigned char *data_ptr = NULL; int packet_length = sizeof(int) + sizeof(target) + sizeof(index) + sizeof(num) + num * 4 * sizeof(GLfloat); CR_GET_BUFFERED_POINTER(pc, packet_length); WRITE_DATA(0, int, packet_length); WRITE_DATA(sizeof(int) + 0, GLenum, target); WRITE_DATA(sizeof(int) + 4, GLuint, index); WRITE_DATA(sizeof(int) + 8, GLuint, num); crMemcpy(data_ptr + sizeof(int) + 12, params, num * 4 * sizeof(GLfloat)); WRITE_OPCODE(pc, CR_PROGRAMPARAMETERS4FVNV_EXTEND_OPCODE); CR_UNLOCK_PACKER_CONTEXT(pc); } void PACK_APIENTRY crPackVertexAttribs1dvNV(GLuint index, GLsizei n, const GLdouble *v) { GLint i; /* reverse order so we hit index 0 last (provoking glVertex) */ for (i = n - 1; i >= 0; i--) crPackVertexAttrib1dvARB(index + i, v + i); } void PACK_APIENTRY crPackVertexAttribs1fvNV(GLuint index, GLsizei n, const GLfloat *v) { GLint i; /* reverse order so we hit index 0 last (provoking glVertex) */ for (i = n - 1; i >= 0; i--) crPackVertexAttrib1fvARB(index + i, v + i); } void PACK_APIENTRY crPackVertexAttribs1svNV(GLuint index, GLsizei n, const GLshort *v) { GLint i; /* reverse order so we hit index 0 last (provoking glVertex) */ for (i = n - 1; i >= 0; i--) crPackVertexAttrib1svARB(index + i, v + i); } void PACK_APIENTRY crPackVertexAttribs2dvNV(GLuint index, GLsizei n, const GLdouble *v) { GLint i; /* reverse order so we hit index 0 last (provoking glVertex) */ for (i = n - 1; i >= 0; i--) crPackVertexAttrib2dvARB(index + i, v + 2 * i); } void PACK_APIENTRY crPackVertexAttribs2fvNV(GLuint index, GLsizei n, const GLfloat *v) { GLint i; /* reverse order so we hit index 0 last (provoking glVertex) */ for (i = n - 1; i >= 0; i--) crPackVertexAttrib2fvARB(index + i, v + 2 * i); } void PACK_APIENTRY crPackVertexAttribs2svNV(GLuint index, GLsizei n, const GLshort *v) { GLint i; /* reverse order so we hit index 0 last (provoking glVertex) */ for (i = n - 1; i >= 0; i--) crPackVertexAttrib2svARB(index + i, v + 2 * i); } void PACK_APIENTRY crPackVertexAttribs3dvNV(GLuint index, GLsizei n, const GLdouble *v) { GLint i; /* reverse order so we hit index 0 last (provoking glVertex) */ for (i = n - 1; i >= 0; i--) crPackVertexAttrib3dvARB(index + i, v + 3 * i); } void PACK_APIENTRY crPackVertexAttribs3fvNV(GLuint index, GLsizei n, const GLfloat *v) { GLint i; /* reverse order so we hit index 0 last (provoking glVertex) */ for (i = n - 1; i >= 0; i--) crPackVertexAttrib3fvARB(index + i, v + 3 * i); } void PACK_APIENTRY crPackVertexAttribs3svNV(GLuint index, GLsizei n, const GLshort *v) { GLint i; /* reverse order so we hit index 0 last (provoking glVertex) */ for (i = n - 1; i >= 0; i--) crPackVertexAttrib3svARB(index + i, v + 3 * i); } void PACK_APIENTRY crPackVertexAttribs4dvNV(GLuint index, GLsizei n, const GLdouble *v) { GLint i; /* reverse order so we hit index 0 last (provoking glVertex) */ for (i = n - 1; i >= 0; i--) crPackVertexAttrib4dvARB(index + i, v + 4 * i); } void PACK_APIENTRY crPackVertexAttribs4fvNV(GLuint index, GLsizei n, const GLfloat *v) { GLint i; /* reverse order so we hit index 0 last (provoking glVertex) */ for (i = n - 1; i >= 0; i--) crPackVertexAttrib4fvARB(index + i, v + 4 * i); } void PACK_APIENTRY crPackVertexAttribs4svNV(GLuint index, GLsizei n, const GLshort *v) { GLint i; /* reverse order so we hit index 0 last (provoking glVertex) */ for (i = n - 1; i >= 0; i--) crPackVertexAttrib4svARB(index + i, v + 4 * i); } void PACK_APIENTRY crPackVertexAttribs4ubvNV(GLuint index, GLsizei n, const GLubyte *v) { GLint i; /* reverse order so we hit index 0 last (provoking glVertex) */ for (i = n - 1; i >= 0; i--) crPackVertexAttrib4ubvARB(index + i, v + 4 * i); } void PACK_APIENTRY crPackExecuteProgramNV(GLenum target, GLuint id, const GLfloat *params) { const int packet_length = 32; unsigned char *data_ptr = NULL; CR_GET_PACKER_CONTEXT(pc); CR_GET_BUFFERED_POINTER(pc, packet_length); WRITE_DATA(0, int, packet_length); WRITE_DATA(4, GLenum, CR_EXECUTEPROGRAMNV_EXTEND_OPCODE); WRITE_DATA(8, GLenum, target); WRITE_DATA(12, GLuint, id); WRITE_DATA(16, GLfloat, params[0]); WRITE_DATA(20, GLfloat, params[1]); WRITE_DATA(24, GLfloat, params[2]); WRITE_DATA(28, GLfloat, params[3]); WRITE_OPCODE(pc, CR_EXTEND_OPCODE); CR_UNLOCK_PACKER_CONTEXT(pc); } void PACK_APIENTRY crPackLoadProgramNV(GLenum target, GLuint id, GLsizei len, const GLubyte *program) { const int packet_length = 20 + len; unsigned char *data_ptr = NULL; CR_GET_PACKER_CONTEXT(pc); CR_GET_BUFFERED_POINTER(pc, packet_length); WRITE_DATA(0, int, packet_length); WRITE_DATA(4, GLenum, CR_LOADPROGRAMNV_EXTEND_OPCODE); WRITE_DATA(8, GLenum, target); WRITE_DATA(12, GLuint, id); WRITE_DATA(16, GLsizei, len); crMemcpy((void *) (data_ptr + 20), program, len); WRITE_OPCODE(pc, CR_EXTEND_OPCODE); CR_UNLOCK_PACKER_CONTEXT(pc); } void PACK_APIENTRY crPackRequestResidentProgramsNV(GLsizei n, const GLuint *ids) { CR_GET_PACKER_CONTEXT(pc); (void) pc; (void) n; (void) ids; /* We're no-op'ing this function for now. */ } void PACK_APIENTRY crPackProgramNamedParameter4fNV (GLuint id, GLsizei len, const GLubyte * name, GLfloat x, GLfloat y, GLfloat z, GLfloat w) { CR_GET_PACKER_CONTEXT(pc); unsigned char *data_ptr = NULL; int packet_length = 32 + len; CR_GET_BUFFERED_POINTER(pc, packet_length); WRITE_DATA(0, GLint, packet_length); WRITE_DATA(4, GLenum, CR_PROGRAMNAMEDPARAMETER4FNV_EXTEND_OPCODE); WRITE_DATA(8, GLuint, id); WRITE_DATA(12, GLsizei, len); WRITE_DATA(16, GLfloat, x); WRITE_DATA(20, GLfloat, y); WRITE_DATA(24, GLfloat, z); WRITE_DATA(28, GLfloat, w); crMemcpy((void *) (data_ptr + 32), name, len); WRITE_OPCODE(pc, CR_EXTEND_OPCODE); CR_UNLOCK_PACKER_CONTEXT(pc); } void PACK_APIENTRY crPackProgramNamedParameter4dNV (GLuint id, GLsizei len, const GLubyte * name, GLdouble x, GLdouble y, GLdouble z, GLdouble w) { CR_GET_PACKER_CONTEXT(pc); unsigned char *data_ptr = NULL; int packet_length = 48 + len; CR_GET_BUFFERED_POINTER(pc, packet_length); WRITE_DATA(0, GLint, packet_length); WRITE_DATA(4, GLenum, CR_PROGRAMNAMEDPARAMETER4DNV_EXTEND_OPCODE); WRITE_DATA(8, GLenum, id); WRITE_DATA(12, GLuint, len); WRITE_DOUBLE(16, x); WRITE_DOUBLE(24, y); WRITE_DOUBLE(32, z); WRITE_DOUBLE(40, w); crMemcpy((void *) (data_ptr + 48), name, len); WRITE_OPCODE(pc, CR_EXTEND_OPCODE); CR_UNLOCK_PACKER_CONTEXT(pc); } void PACK_APIENTRY crPackProgramNamedParameter4fvNV (GLuint id, GLsizei len, const GLubyte * name, const GLfloat * v) { crPackProgramNamedParameter4fNV(id, len, name, v[0], v[1], v[2], v[3]); } void PACK_APIENTRY crPackProgramNamedParameter4dvNV (GLuint id, GLsizei len, const GLubyte * name, const GLdouble * v) { crPackProgramNamedParameter4dNV(id, len, name, v[0], v[1], v[2], v[3]); } void PACK_APIENTRY crPackAreProgramsResidentNV(GLsizei n, const GLuint * programs, GLboolean *residences, GLboolean *return_val, int *writeback) { CR_GET_PACKER_CONTEXT(pc); unsigned char *data_ptr = NULL; int packet_length; (void) return_val; /* Caller must compute this from residences!!! */ packet_length = sizeof(int) + /* packet length */ sizeof(GLenum) + /* extend opcode */ sizeof(n) + /* num programs */ n * sizeof(*programs) + /* programs */ 8 + 8; CR_GET_BUFFERED_POINTER(pc, packet_length); WRITE_DATA(0, int, packet_length); WRITE_DATA(4, GLenum, CR_AREPROGRAMSRESIDENTNV_EXTEND_OPCODE); WRITE_DATA(8, GLsizei, n); crMemcpy(data_ptr + 12, programs, n * sizeof(*programs)); WRITE_NETWORK_POINTER(12 + n * sizeof(*programs), (void *) residences); WRITE_NETWORK_POINTER(20 + n * sizeof(*programs), (void *) writeback); WRITE_OPCODE(pc, CR_EXTEND_OPCODE); CR_CMDBLOCK_CHECK_FLUSH(pc); CR_UNLOCK_PACKER_CONTEXT(pc); } void PACK_APIENTRY crPackGetProgramNamedParameterfvNV(GLuint id, GLsizei len, const GLubyte *name, GLfloat *params, int *writeback) { int packet_length = 32 + len; CR_GET_PACKER_CONTEXT(pc); unsigned char *data_ptr = NULL; CR_GET_BUFFERED_POINTER(pc, packet_length); WRITE_DATA(0, GLint, packet_length); WRITE_DATA(4, GLenum, CR_GETPROGRAMNAMEDPARAMETERFVNV_EXTEND_OPCODE); WRITE_DATA(8, GLuint, id); WRITE_DATA(12, GLsizei, len); crMemcpy(data_ptr + 16, name, len); WRITE_NETWORK_POINTER(16 + len, (void *) params); WRITE_NETWORK_POINTER(16 + len + 8, (void *) writeback); WRITE_OPCODE(pc, CR_EXTEND_OPCODE); CR_CMDBLOCK_CHECK_FLUSH(pc); CR_UNLOCK_PACKER_CONTEXT(pc); } void PACK_APIENTRY crPackGetProgramNamedParameterdvNV(GLuint id, GLsizei len, const GLubyte *name, GLdouble *params, int *writeback) { int packet_length = 32 + len; CR_GET_PACKER_CONTEXT(pc); unsigned char *data_ptr = NULL; CR_GET_BUFFERED_POINTER(pc, packet_length); WRITE_DATA(0, GLint, packet_length); WRITE_DATA(4, GLenum, CR_GETPROGRAMNAMEDPARAMETERDVNV_EXTEND_OPCODE); WRITE_DATA(8, GLuint, id); WRITE_DATA(12, GLsizei, len); crMemcpy(data_ptr + 16, name, len); WRITE_NETWORK_POINTER(16 + len, (void *) params); WRITE_NETWORK_POINTER(16 + len + 8, (void *) writeback); WRITE_OPCODE(pc, CR_EXTEND_OPCODE); CR_CMDBLOCK_CHECK_FLUSH(pc); CR_UNLOCK_PACKER_CONTEXT(pc); } void PACK_APIENTRY crPackDeleteProgramsARB(GLsizei n, const GLuint *ids) { unsigned char *data_ptr = NULL; int packet_length = sizeof(GLenum) + sizeof(n) + n * sizeof(*ids); if (!ids) return; data_ptr = (unsigned char *) crPackAlloc(packet_length); WRITE_DATA(0, GLenum, CR_DELETEPROGRAMSARB_EXTEND_OPCODE); WRITE_DATA(4, GLsizei, n); crMemcpy(data_ptr + 8, ids, n * sizeof(*ids)); crHugePacket(CR_EXTEND_OPCODE, data_ptr); crPackFree(data_ptr); } void PACK_APIENTRY crPackProgramStringARB(GLenum target, GLenum format, GLsizei len, const void *string) { const int packet_length = 20 + len; unsigned char *data_ptr = NULL; CR_GET_PACKER_CONTEXT(pc); CR_GET_BUFFERED_POINTER(pc, packet_length); WRITE_DATA(0, int, packet_length); WRITE_DATA(4, GLenum, CR_PROGRAMSTRINGARB_EXTEND_OPCODE); WRITE_DATA(8, GLenum, target); WRITE_DATA(12, GLuint, format); WRITE_DATA(16, GLsizei, len); crMemcpy((void *) (data_ptr + 20), string, len); WRITE_OPCODE(pc, CR_EXTEND_OPCODE); CR_UNLOCK_PACKER_CONTEXT(pc); } /* * Can't easily auto-generate these functions since there aren't * non-vector versions. */ void PACK_APIENTRY crPackVertexAttrib4NbvARB(GLuint index, const GLbyte *v) { CR_GET_PACKER_CONTEXT(pc); unsigned char *data_ptr = NULL; CR_GET_BUFFERED_POINTER(pc, 8); pc->current.c.vertexAttrib.b4[index] = data_ptr + 4; pc->current.attribsUsedMask |= (1 << index); WRITE_DATA(0, GLuint, index); WRITE_DATA(4, GLbyte, v[0]); WRITE_DATA(5, GLbyte, v[1]); WRITE_DATA(6, GLbyte, v[2]); WRITE_DATA(7, GLbyte, v[3]); WRITE_OPCODE(pc, CR_VERTEXATTRIB4NBVARB_OPCODE); CR_UNLOCK_PACKER_CONTEXT(pc); } void PACK_APIENTRY crPackVertexAttrib4NivARB(GLuint index, const GLint *v) { CR_GET_PACKER_CONTEXT(pc); unsigned char *data_ptr = NULL; CR_GET_BUFFERED_POINTER(pc, 20); pc->current.c.vertexAttrib.i4[index] = data_ptr + 4; pc->current.attribsUsedMask |= (1 << index); WRITE_DATA(0, GLuint, index); WRITE_DATA(4, GLint, v[0]); WRITE_DATA(8, GLint, v[1]); WRITE_DATA(12, GLint, v[2]); WRITE_DATA(16, GLint, v[3]); WRITE_OPCODE(pc, CR_VERTEXATTRIB4NIVARB_OPCODE); CR_UNLOCK_PACKER_CONTEXT(pc); } void PACK_APIENTRY crPackVertexAttrib4NsvARB(GLuint index, const GLshort *v) { CR_GET_PACKER_CONTEXT(pc); unsigned char *data_ptr = NULL; CR_GET_BUFFERED_POINTER(pc, 12); pc->current.c.vertexAttrib.s4[index] = data_ptr + 4; pc->current.attribsUsedMask |= (1 << index); WRITE_DATA(0, GLuint, index); WRITE_DATA(4, GLshort, v[0]); WRITE_DATA(6, GLshort, v[1]); WRITE_DATA(8, GLshort, v[2]); WRITE_DATA(10, GLshort, v[3]); WRITE_OPCODE(pc, CR_VERTEXATTRIB4NSVARB_OPCODE); CR_UNLOCK_PACKER_CONTEXT(pc); } void PACK_APIENTRY crPackVertexAttrib4NubvARB(GLuint index, const GLubyte * v) { CR_GET_PACKER_CONTEXT(pc); unsigned char *data_ptr = NULL; CR_GET_BUFFERED_POINTER(pc, 8); pc->current.c.vertexAttrib.ub4[index] = data_ptr + 4; pc->current.attribsUsedMask |= (1 << index); WRITE_DATA(0, GLuint, index); WRITE_DATA(4, GLubyte, v[0]); WRITE_DATA(5, GLubyte, v[1]); WRITE_DATA(6, GLubyte, v[2]); WRITE_DATA(7, GLubyte, v[3]); WRITE_OPCODE(pc, CR_VERTEXATTRIB4NUBVARB_OPCODE); CR_UNLOCK_PACKER_CONTEXT(pc); } void PACK_APIENTRY crPackVertexAttrib4NuivARB(GLuint index, const GLuint * v) { CR_GET_PACKER_CONTEXT(pc); unsigned char *data_ptr = NULL; CR_GET_BUFFERED_POINTER(pc, 20); pc->current.c.vertexAttrib.ui4[index] = data_ptr + 4; pc->current.attribsUsedMask |= (1 << index); WRITE_DATA(0, GLuint, index); WRITE_DATA(4, GLuint, v[0]); WRITE_DATA(8, GLuint, v[1]); WRITE_DATA(12, GLuint, v[2]); WRITE_DATA(16, GLuint, v[3]); WRITE_OPCODE(pc, CR_VERTEXATTRIB4NUIVARB_OPCODE); CR_UNLOCK_PACKER_CONTEXT(pc); } void PACK_APIENTRY crPackVertexAttrib4NusvARB(GLuint index, const GLushort * v) { CR_GET_PACKER_CONTEXT(pc); unsigned char *data_ptr = NULL; CR_GET_BUFFERED_POINTER(pc, 12); pc->current.c.vertexAttrib.s4[index] = data_ptr + 4; pc->current.attribsUsedMask |= (1 << index); WRITE_DATA(0, GLuint, index); WRITE_DATA(4, GLushort, v[0]); WRITE_DATA(6, GLushort, v[1]); WRITE_DATA(8, GLushort, v[2]); WRITE_DATA(10, GLushort, v[3]); WRITE_OPCODE(pc, CR_VERTEXATTRIB4NUSVARB_OPCODE); CR_UNLOCK_PACKER_CONTEXT(pc); } void PACK_APIENTRY crPackVertexAttrib4bvARB(GLuint index, const GLbyte * v) { CR_GET_PACKER_CONTEXT(pc); unsigned char *data_ptr = NULL; CR_GET_BUFFERED_POINTER(pc, 8); pc->current.c.vertexAttrib.b4[index] = data_ptr + 4; pc->current.attribsUsedMask |= (1 << index); WRITE_DATA(0, GLuint, index); WRITE_DATA(4, GLbyte, v[0]); WRITE_DATA(5, GLbyte, v[1]); WRITE_DATA(6, GLbyte, v[2]); WRITE_DATA(7, GLbyte, v[3]); WRITE_OPCODE(pc, CR_VERTEXATTRIB4BVARB_OPCODE); CR_UNLOCK_PACKER_CONTEXT(pc); } void PACK_APIENTRY crPackVertexAttrib4ivARB(GLuint index, const GLint * v) { CR_GET_PACKER_CONTEXT(pc); unsigned char *data_ptr = NULL; CR_GET_BUFFERED_POINTER(pc, 20); pc->current.c.vertexAttrib.i4[index] = data_ptr + 4; pc->current.attribsUsedMask |= (1 << index); WRITE_DATA(0, GLuint, index); WRITE_DATA(4, GLint, v[0]); WRITE_DATA(8, GLint, v[1]); WRITE_DATA(12, GLint, v[2]); WRITE_DATA(16, GLint, v[3]); WRITE_OPCODE(pc, CR_VERTEXATTRIB4IVARB_OPCODE); CR_UNLOCK_PACKER_CONTEXT(pc); } void PACK_APIENTRY crPackVertexAttrib4uivARB(GLuint index, const GLuint * v) { CR_GET_PACKER_CONTEXT(pc); unsigned char *data_ptr = NULL; CR_GET_BUFFERED_POINTER(pc, 20); pc->current.c.vertexAttrib.ui4[index] = data_ptr + 4; pc->current.attribsUsedMask |= (1 << index); WRITE_DATA(0, GLuint, index); WRITE_DATA(4, GLuint, v[0]); WRITE_DATA(8, GLuint, v[1]); WRITE_DATA(12, GLuint, v[2]); WRITE_DATA(16, GLuint, v[3]); WRITE_OPCODE(pc, CR_VERTEXATTRIB4UIVARB_OPCODE); CR_UNLOCK_PACKER_CONTEXT(pc); } void PACK_APIENTRY crPackVertexAttrib4usvARB(GLuint index, const GLushort * v) { CR_GET_PACKER_CONTEXT(pc); unsigned char *data_ptr = NULL; CR_GET_BUFFERED_POINTER(pc, 12); pc->current.c.vertexAttrib.s4[index] = data_ptr + 4; pc->current.attribsUsedMask |= (1 << index); WRITE_DATA(0, GLuint, index); WRITE_DATA(4, GLushort, v[0]); WRITE_DATA(6, GLushort, v[1]); WRITE_DATA(8, GLushort, v[2]); WRITE_DATA(10, GLushort, v[3]); WRITE_OPCODE(pc, CR_VERTEXATTRIB4USVARB_OPCODE); CR_UNLOCK_PACKER_CONTEXT(pc); } void PACK_APIENTRY crPackVertexAttrib4ubvARB(GLuint index, const GLubyte * v) { CR_GET_PACKER_CONTEXT(pc); unsigned char *data_ptr = NULL; CR_GET_BUFFERED_POINTER(pc, 8); pc->current.c.vertexAttrib.ub4[index] = data_ptr + 4; pc->current.attribsUsedMask |= (1 << index); WRITE_DATA(0, GLuint, index); WRITE_DATA(4, GLubyte, v[0]); WRITE_DATA(5, GLubyte, v[1]); WRITE_DATA(6, GLubyte, v[2]); WRITE_DATA(7, GLubyte, v[3]); WRITE_OPCODE(pc, CR_VERTEXATTRIB4UBVARB_OPCODE); CR_UNLOCK_PACKER_CONTEXT(pc); }