diff options
Diffstat (limited to 'mesalib/src/mesa/program')
| -rw-r--r-- | mesalib/src/mesa/program/ir_to_mesa.cpp | 2 | ||||
| -rw-r--r-- | mesalib/src/mesa/program/nvfragparse.c | 1591 | ||||
| -rw-r--r-- | mesalib/src/mesa/program/nvfragparse.h | 47 | ||||
| -rw-r--r-- | mesalib/src/mesa/program/nvvertparse.c | 1456 | ||||
| -rw-r--r-- | mesalib/src/mesa/program/nvvertparse.h | 49 | ||||
| -rw-r--r-- | mesalib/src/mesa/program/prog_execute.c | 66 | ||||
| -rw-r--r-- | mesalib/src/mesa/program/prog_instruction.c | 7 | ||||
| -rw-r--r-- | mesalib/src/mesa/program/prog_instruction.h | 29 | ||||
| -rw-r--r-- | mesalib/src/mesa/program/prog_optimize.c | 3 | ||||
| -rw-r--r-- | mesalib/src/mesa/program/prog_parameter.c | 100 | ||||
| -rw-r--r-- | mesalib/src/mesa/program/prog_parameter.h | 36 | ||||
| -rw-r--r-- | mesalib/src/mesa/program/prog_parameter_layout.c | 2 | ||||
| -rw-r--r-- | mesalib/src/mesa/program/prog_print.c | 84 | ||||
| -rw-r--r-- | mesalib/src/mesa/program/prog_print.h | 1 | ||||
| -rw-r--r-- | mesalib/src/mesa/program/prog_statevars.c | 91 | ||||
| -rw-r--r-- | mesalib/src/mesa/program/prog_statevars.h | 3 | ||||
| -rw-r--r-- | mesalib/src/mesa/program/program.c | 12 | ||||
| -rw-r--r-- | mesalib/src/mesa/program/program_parse.y | 7 | ||||
| -rw-r--r-- | mesalib/src/mesa/program/programopt.c | 7 | 
19 files changed, 23 insertions, 3570 deletions
| diff --git a/mesalib/src/mesa/program/ir_to_mesa.cpp b/mesalib/src/mesa/program/ir_to_mesa.cpp index 4991a551c..d5b9683db 100644 --- a/mesalib/src/mesa/program/ir_to_mesa.cpp +++ b/mesalib/src/mesa/program/ir_to_mesa.cpp @@ -2407,7 +2407,7 @@ add_uniform_to_shader::visit_field(const glsl_type *type, const char *name)     int index = _mesa_lookup_parameter_index(params, -1, name);     if (index < 0) {        index = _mesa_add_parameter(params, file, name, size, type->gl_type, -				  NULL, NULL, 0x0); +				  NULL, NULL);        /* Sampler uniform values are stored in prog->SamplerUnits,         * and the entry in that array is selected by this index we diff --git a/mesalib/src/mesa/program/nvfragparse.c b/mesalib/src/mesa/program/nvfragparse.c deleted file mode 100644 index f251d7e6c..000000000 --- a/mesalib/src/mesa/program/nvfragparse.c +++ /dev/null @@ -1,1591 +0,0 @@ -/* - * Mesa 3-D graphics library - * Version:  6.5 - * - * Copyright (C) 1999-2005  Brian Paul   All Rights Reserved. - * - * Permission is hereby granted, free of charge, to any person obtaining a - * copy of this software and associated documentation files (the "Software"), - * to deal in the Software without restriction, including without limitation - * the rights to use, copy, modify, merge, publish, distribute, sublicense, - * and/or sell copies of the Software, and to permit persons to whom the - * Software is furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included - * in all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS - * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL - * BRIAN PAUL BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN - * AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN - * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - */ - -/** - * \file nvfragparse.c - * NVIDIA fragment program parser. - * \author Brian Paul - */ - -/* - * Regarding GL_NV_fragment_program: - * - * Portions of this software may use or implement intellectual - * property owned and licensed by NVIDIA Corporation. NVIDIA disclaims - * any and all warranties with respect to such intellectual property, - * including any use thereof or modifications thereto. - */ - -#include "main/glheader.h" -#include "main/context.h" -#include "main/imports.h" -#include "main/macros.h" -#include "program.h" -#include "prog_parameter.h" -#include "prog_print.h" -#include "prog_instruction.h" -#include "nvfragparse.h" - - -#define INPUT_1V     1 -#define INPUT_2V     2 -#define INPUT_3V     3 -#define INPUT_1S     4 -#define INPUT_2S     5 -#define INPUT_CC     6 -#define INPUT_1V_T   7  /* one source vector, plus textureId */ -#define INPUT_3V_T   8  /* one source vector, plus textureId */ -#define INPUT_NONE   9 -#define INPUT_1V_S  10  /* a string and a vector register */ -#define OUTPUT_V    20 -#define OUTPUT_S    21 -#define OUTPUT_NONE 22 - -/* IRIX defines some of these */ -#undef _R -#undef _H -#undef _X -#undef _C -#undef _S - -/* Optional suffixes */ -#define _R  FLOAT32  /* float */ -#define _H  FLOAT16  /* half-float */ -#define _X  FIXED12  /* fixed */ -#define _C  0x08     /* set cond codes */ -#define _S  0x10     /* saturate, clamp result to [0,1] */ - -struct instruction_pattern { -   const char *name; -   enum prog_opcode opcode; -   GLuint inputs; -   GLuint outputs; -   GLuint suffixes; -}; - -static const struct instruction_pattern Instructions[] = { -   { "ADD", OPCODE_ADD, INPUT_2V, OUTPUT_V, _R | _H | _X | _C | _S }, -   { "COS", OPCODE_COS, INPUT_1S, OUTPUT_S, _R | _H |      _C | _S }, -   { "DDX", OPCODE_DDX, INPUT_1V, OUTPUT_V, _R | _H |      _C | _S }, -   { "DDY", OPCODE_DDY, INPUT_1V, OUTPUT_V, _R | _H |      _C | _S }, -   { "DP3", OPCODE_DP3, INPUT_2V, OUTPUT_S, _R | _H | _X | _C | _S }, -   { "DP4", OPCODE_DP4, INPUT_2V, OUTPUT_S, _R | _H | _X | _C | _S }, -   { "DST", OPCODE_DP4, INPUT_2V, OUTPUT_V, _R | _H |      _C | _S }, -   { "EX2", OPCODE_DP4, INPUT_1S, OUTPUT_S, _R | _H |      _C | _S }, -   { "FLR", OPCODE_FLR, INPUT_1V, OUTPUT_V, _R | _H | _X | _C | _S }, -   { "FRC", OPCODE_FRC, INPUT_1V, OUTPUT_V, _R | _H | _X | _C | _S }, -   { "KIL", OPCODE_KIL_NV, INPUT_CC, OUTPUT_NONE, 0                }, -   { "LG2", OPCODE_LG2, INPUT_1S, OUTPUT_S, _R | _H |      _C | _S }, -   { "LIT", OPCODE_LIT, INPUT_1V, OUTPUT_V, _R | _H |      _C | _S }, -   { "LRP", OPCODE_LRP, INPUT_3V, OUTPUT_V, _R | _H | _X | _C | _S }, -   { "MAD", OPCODE_MAD, INPUT_3V, OUTPUT_V, _R | _H | _X | _C | _S }, -   { "MAX", OPCODE_MAX, INPUT_2V, OUTPUT_V, _R | _H | _X | _C | _S }, -   { "MIN", OPCODE_MIN, INPUT_2V, OUTPUT_V, _R | _H | _X | _C | _S }, -   { "MOV", OPCODE_MOV, INPUT_1V, OUTPUT_V, _R | _H | _X | _C | _S }, -   { "MUL", OPCODE_MUL, INPUT_2V, OUTPUT_V, _R | _H | _X | _C | _S }, -   { "PK2H",  OPCODE_PK2H,  INPUT_1V, OUTPUT_S, 0                  }, -   { "PK2US", OPCODE_PK2US, INPUT_1V, OUTPUT_S, 0                  }, -   { "PK4B",  OPCODE_PK4B,  INPUT_1V, OUTPUT_S, 0                  }, -   { "PK4UB", OPCODE_PK4UB, INPUT_1V, OUTPUT_S, 0                  }, -   { "POW", OPCODE_POW, INPUT_2S, OUTPUT_S, _R | _H |      _C | _S }, -   { "RCP", OPCODE_RCP, INPUT_1S, OUTPUT_S, _R | _H |      _C | _S }, -   { "RFL", OPCODE_RFL, INPUT_2V, OUTPUT_V, _R | _H |      _C | _S }, -   { "RSQ", OPCODE_RSQ, INPUT_1S, OUTPUT_S, _R | _H |      _C | _S }, -   { "SEQ", OPCODE_SEQ, INPUT_2V, OUTPUT_V, _R | _H | _X | _C | _S }, -   { "SFL", OPCODE_SFL, INPUT_2V, OUTPUT_V, _R | _H | _X | _C | _S }, -   { "SGE", OPCODE_SGE, INPUT_2V, OUTPUT_V, _R | _H | _X | _C | _S }, -   { "SGT", OPCODE_SGT, INPUT_2V, OUTPUT_V, _R | _H | _X | _C | _S }, -   { "SIN", OPCODE_SIN, INPUT_1S, OUTPUT_S, _R | _H |      _C | _S }, -   { "SLE", OPCODE_SLE, INPUT_2V, OUTPUT_V, _R | _H | _X | _C | _S }, -   { "SLT", OPCODE_SLT, INPUT_2V, OUTPUT_V, _R | _H | _X | _C | _S }, -   { "SNE", OPCODE_SNE, INPUT_2V, OUTPUT_V, _R | _H | _X | _C | _S }, -   { "STR", OPCODE_STR, INPUT_2V, OUTPUT_V, _R | _H | _X | _C | _S }, -   { "SUB", OPCODE_SUB, INPUT_2V, OUTPUT_V, _R | _H | _X | _C | _S }, -   { "TEX", OPCODE_TEX, INPUT_1V_T, OUTPUT_V,              _C | _S }, -   { "TXD", OPCODE_TXD, INPUT_3V_T, OUTPUT_V,              _C | _S }, -   { "TXP", OPCODE_TXP_NV, INPUT_1V_T, OUTPUT_V,           _C | _S }, -   { "UP2H",  OPCODE_UP2H,  INPUT_1S, OUTPUT_V,            _C | _S }, -   { "UP2US", OPCODE_UP2US, INPUT_1S, OUTPUT_V,            _C | _S }, -   { "UP4B",  OPCODE_UP4B,  INPUT_1S, OUTPUT_V,            _C | _S }, -   { "UP4UB", OPCODE_UP4UB, INPUT_1S, OUTPUT_V,            _C | _S }, -   { "X2D", OPCODE_X2D, INPUT_3V, OUTPUT_V, _R | _H |      _C | _S }, -   { "PRINT", OPCODE_PRINT, INPUT_1V_S, OUTPUT_NONE, 0               }, -   { NULL, (enum prog_opcode) -1, 0, 0, 0 } -}; - - -/* - * Information needed or computed during parsing. - * Remember, we can't modify the target program object until we've - * _successfully_ parsed the program text. - */ -struct parse_state { -   struct gl_context *ctx; -   const GLubyte *start;              /* start of program string */ -   const GLubyte *pos;                /* current position */ -   const GLubyte *curLine; -   struct gl_fragment_program *program;  /* current program */ - -   struct gl_program_parameter_list *parameters; - -   GLuint numInst;                    /* number of instructions parsed */ -   GLuint inputsRead;                 /* bitmask of input registers used */ -   GLuint outputsWritten;             /* bitmask of 1 << FRAG_OUTPUT_* bits */ -   GLuint texturesUsed[MAX_TEXTURE_IMAGE_UNITS]; -}; - - - -/* - * Called whenever we find an error during parsing. - */ -static void -record_error(struct parse_state *parseState, const char *msg, int lineNo) -{ -#ifdef DEBUG -   GLint line, column; -   const GLubyte *lineStr; -   lineStr = _mesa_find_line_column(parseState->start, -                                    parseState->pos, &line, &column); -   _mesa_debug(parseState->ctx, -               "nvfragparse.c(%d): line %d, column %d:%s (%s)\n", -               lineNo, line, column, (char *) lineStr, msg); -   free((void *) lineStr); -#else -   (void) lineNo; -#endif - -   /* Check that no error was already recorded.  Only record the first one. */ -   if (parseState->ctx->Program.ErrorString[0] == 0) { -      _mesa_set_program_error(parseState->ctx, -                              parseState->pos - parseState->start, -                              msg); -   } -} - - -#define RETURN_ERROR							\ -do {									\ -   record_error(parseState, "Unexpected end of input.", __LINE__);	\ -   return GL_FALSE;							\ -} while(0) - -#define RETURN_ERROR1(msg)						\ -do {									\ -   record_error(parseState, msg, __LINE__);				\ -   return GL_FALSE;							\ -} while(0) - -#define RETURN_ERROR2(msg1, msg2)					\ -do {									\ -   char err[1000];							\ -   sprintf(err, "%s %s", msg1, msg2);				\ -   record_error(parseState, err, __LINE__);				\ -   return GL_FALSE;							\ -} while(0) - - - - -/* - * Search a list of instruction structures for a match. - */ -static struct instruction_pattern -MatchInstruction(const GLubyte *token) -{ -   const struct instruction_pattern *inst; -   struct instruction_pattern result; - -   result.name = NULL; -   result.opcode = MAX_OPCODE; /* i.e. invalid instruction */ -   result.inputs = 0; -   result.outputs = 0; -   result.suffixes = 0; - -   for (inst = Instructions; inst->name; inst++) { -      if (strncmp((const char *) token, inst->name, 3) == 0) { -         /* matched! */ -         int i = 3; -         result = *inst; -         result.suffixes = 0; -         /* look at suffix */ -         if (token[i] == 'R') { -            result.suffixes |= _R; -            i++; -         } -         else if (token[i] == 'H') { -            result.suffixes |= _H; -            i++; -         } -         else if (token[i] == 'X') { -            result.suffixes |= _X; -            i++; -         } -         if (token[i] == 'C') { -            result.suffixes |= _C; -            i++; -         } -         if (token[i] == '_' && token[i+1] == 'S' && -             token[i+2] == 'A' && token[i+3] == 'T') { -            result.suffixes |= _S; -         } -         return result; -      } -   } - -   return result; -} - - - - -/**********************************************************************/ - - -static GLboolean IsLetter(GLubyte b) -{ -   return (b >= 'a' && b <= 'z') || -          (b >= 'A' && b <= 'Z') || -          (b == '_') || -          (b == '$'); -} - - -static GLboolean IsDigit(GLubyte b) -{ -   return b >= '0' && b <= '9'; -} - - -static GLboolean IsWhitespace(GLubyte b) -{ -   return b == ' ' || b == '\t' || b == '\n' || b == '\r'; -} - - -/** - * Starting at 'str' find the next token.  A token can be an integer, - * an identifier or punctuation symbol. - * \return <= 0 we found an error, else, return number of characters parsed. - */ -static GLint -GetToken(struct parse_state *parseState, GLubyte *token) -{ -   const GLubyte *str = parseState->pos; -   GLint i = 0, j = 0; - -   token[0] = 0; - -   /* skip whitespace and comments */ -   while (str[i] && (IsWhitespace(str[i]) || str[i] == '#')) { -      if (str[i] == '#') { -         /* skip comment */ -         while (str[i] && (str[i] != '\n' && str[i] != '\r')) { -            i++; -         } -         if (str[i] == '\n' || str[i] == '\r') -            parseState->curLine = str + i + 1; -      } -      else { -         /* skip whitespace */ -         if (str[i] == '\n' || str[i] == '\r') -            parseState->curLine = str + i + 1; -         i++; -      } -   } - -   if (str[i] == 0) -      return -i; - -   /* try matching an integer */ -   while (str[i] && IsDigit(str[i])) { -      token[j++] = str[i++]; -   } -   if (j > 0 || !str[i]) { -      token[j] = 0; -      return i; -   } - -   /* try matching an identifier */ -   if (IsLetter(str[i])) { -      while (str[i] && (IsLetter(str[i]) || IsDigit(str[i]))) { -         token[j++] = str[i++]; -      } -      token[j] = 0; -      return i; -   } - -   /* punctuation character */ -   if (str[i]) { -      token[0] = str[i++]; -      token[1] = 0; -      return i; -   } - -   /* end of input */ -   token[0] = 0; -   return i; -} - - -/** - * Get next token from input stream and increment stream pointer past token. - */ -static GLboolean -Parse_Token(struct parse_state *parseState, GLubyte *token) -{ -   GLint i; -   i = GetToken(parseState, token); -   if (i <= 0) { -      parseState->pos += (-i); -      return GL_FALSE; -   } -   parseState->pos += i; -   return GL_TRUE; -} - - -/** - * Get next token from input stream but don't increment stream pointer. - */ -static GLboolean -Peek_Token(struct parse_state *parseState, GLubyte *token) -{ -   GLint i, len; -   i = GetToken(parseState, token); -   if (i <= 0) { -      parseState->pos += (-i); -      return GL_FALSE; -   } -   len = (GLint) strlen((const char *) token); -   parseState->pos += (i - len); -   return GL_TRUE; -} - - -/**********************************************************************/ - -static const char *InputRegisters[MAX_NV_FRAGMENT_PROGRAM_INPUTS + 1] = { -   "WPOS", "COL0", "COL1", "FOGC", -   "TEX0", "TEX1", "TEX2", "TEX3", "TEX4", "TEX5", "TEX6", "TEX7", NULL -}; - - - -/**********************************************************************/ - -/** - * Try to match 'pattern' as the next token after any whitespace/comments. - */ -static GLboolean -Parse_String(struct parse_state *parseState, const char *pattern) -{ -   const GLubyte *m; -   GLint i; - -   /* skip whitespace and comments */ -   while (IsWhitespace(*parseState->pos) || *parseState->pos == '#') { -      if (*parseState->pos == '#') { -         while (*parseState->pos && (*parseState->pos != '\n' && *parseState->pos != '\r')) { -            parseState->pos += 1; -         } -         if (*parseState->pos == '\n' || *parseState->pos == '\r') -            parseState->curLine = parseState->pos + 1; -      } -      else { -         /* skip whitespace */ -         if (*parseState->pos == '\n' || *parseState->pos == '\r') -            parseState->curLine = parseState->pos + 1; -         parseState->pos += 1; -      } -   } - -   /* Try to match the pattern */ -   m = parseState->pos; -   for (i = 0; pattern[i]; i++) { -      if (*m != (GLubyte) pattern[i]) -         return GL_FALSE; -      m += 1; -   } -   parseState->pos = m; - -   return GL_TRUE; /* success */ -} - - -static GLboolean -Parse_Identifier(struct parse_state *parseState, GLubyte *ident) -{ -   if (!Parse_Token(parseState, ident)) -      RETURN_ERROR; -   if (IsLetter(ident[0])) -      return GL_TRUE; -   else -      RETURN_ERROR1("Expected an identfier"); -} - - -/** - * Parse a floating point constant, or a defined symbol name. - * [+/-]N[.N[eN]] - * Output:  number[0 .. 3] will get the value. - */ -static GLboolean -Parse_ScalarConstant(struct parse_state *parseState, GLfloat *number) -{ -   char *end = NULL; - -   *number = (GLfloat) _mesa_strtof((const char *) parseState->pos, &end); - -   if (end && end > (char *) parseState->pos) { -      /* got a number */ -      parseState->pos = (GLubyte *) end; -      number[1] = *number; -      number[2] = *number; -      number[3] = *number; -      return GL_TRUE; -   } -   else { -      /* should be an identifier */ -      GLubyte ident[100]; -      const GLfloat *constant; -      if (!Parse_Identifier(parseState, ident)) -         RETURN_ERROR1("Expected an identifier"); -      constant = (GLfloat *)_mesa_lookup_parameter_value(parseState->parameters, -                                                         -1,  -                                                         (const char *) ident); -      /* XXX Check that it's a constant and not a parameter */ -      if (!constant) { -         RETURN_ERROR1("Undefined symbol"); -      } -      else { -         COPY_4V(number, constant); -         return GL_TRUE; -      } -   } -} - - - -/** - * Parse a vector constant, one of: - *   { float } - *   { float, float } - *   { float, float, float } - *   { float, float, float, float } - */ -static GLboolean -Parse_VectorConstant(struct parse_state *parseState, GLfloat *vec) -{ -   /* "{" was already consumed */ - -   ASSIGN_4V(vec, 0.0, 0.0, 0.0, 1.0); - -   if (!Parse_ScalarConstant(parseState, vec+0))  /* X */ -      return GL_FALSE; - -   if (Parse_String(parseState, "}")) { -      return GL_TRUE; -   } - -   if (!Parse_String(parseState, ",")) -      RETURN_ERROR1("Expected comma in vector constant"); - -   if (!Parse_ScalarConstant(parseState, vec+1))  /* Y */ -      return GL_FALSE; - -   if (Parse_String(parseState, "}")) { -      return GL_TRUE; -   } - -   if (!Parse_String(parseState, ",")) -      RETURN_ERROR1("Expected comma in vector constant"); - -   if (!Parse_ScalarConstant(parseState, vec+2))  /* Z */ -      return GL_FALSE; - -   if (Parse_String(parseState, "}")) { -      return GL_TRUE; -   } - -   if (!Parse_String(parseState, ",")) -      RETURN_ERROR1("Expected comma in vector constant"); - -   if (!Parse_ScalarConstant(parseState, vec+3))  /* W */ -      return GL_FALSE; - -   if (!Parse_String(parseState, "}")) -      RETURN_ERROR1("Expected closing brace in vector constant"); - -   return GL_TRUE; -} - - -/** - * Parse <number>, <varname> or {a, b, c, d}. - * Return number of values in the vector or scalar, or zero if parse error. - */ -static GLuint -Parse_VectorOrScalarConstant(struct parse_state *parseState, GLfloat *vec) -{ -   if (Parse_String(parseState, "{")) { -      return Parse_VectorConstant(parseState, vec); -   } -   else { -      GLboolean b = Parse_ScalarConstant(parseState, vec); -      if (b) { -         vec[1] = vec[2] = vec[3] = vec[0]; -      } -      return b; -   } -} - - -/** - * Parse a texture image source: - *    [TEX0 | TEX1 | .. | TEX15] , [1D | 2D | 3D | CUBE | RECT] - */ -static GLboolean -Parse_TextureImageId(struct parse_state *parseState, -                     GLubyte *texUnit, GLubyte *texTarget) -{ -   GLubyte imageSrc[100]; -   GLint unit; - -   if (!Parse_Token(parseState, imageSrc)) -      RETURN_ERROR; -    -   if (imageSrc[0] != 'T' || -       imageSrc[1] != 'E' || -       imageSrc[2] != 'X') { -      RETURN_ERROR1("Expected TEX# source"); -   } -   unit = atoi((const char *) imageSrc + 3); -   if ((unit < 0 || unit >= MAX_TEXTURE_IMAGE_UNITS) || -       (unit == 0 && (imageSrc[3] != '0' || imageSrc[4] != 0))) { -      RETURN_ERROR1("Invalied TEX# source index"); -   } -   *texUnit = unit; - -   if (!Parse_String(parseState, ",")) -      RETURN_ERROR1("Expected ,"); - -   if (Parse_String(parseState, "1D")) { -      *texTarget = TEXTURE_1D_INDEX; -   } -   else if (Parse_String(parseState, "2D")) { -      *texTarget = TEXTURE_2D_INDEX; -   } -   else if (Parse_String(parseState, "3D")) { -      *texTarget = TEXTURE_3D_INDEX; -   } -   else if (Parse_String(parseState, "CUBE")) { -      *texTarget = TEXTURE_CUBE_INDEX; -   } -   else if (Parse_String(parseState, "RECT")) { -      *texTarget = TEXTURE_RECT_INDEX; -   } -   else { -      RETURN_ERROR1("Invalid texture target token"); -   } - -   /* update record of referenced texture units */ -   parseState->texturesUsed[*texUnit] |= (1 << *texTarget); -   if (_mesa_bitcount(parseState->texturesUsed[*texUnit]) > 1) { -      RETURN_ERROR1("Only one texture target can be used per texture unit."); -   } - -   return GL_TRUE; -} - - -/** - * Parse a scalar suffix like .x, .y, .z or .w or parse a swizzle suffix - * like .wxyz, .xxyy, etc and return the swizzle indexes. - */ -static GLboolean -Parse_SwizzleSuffix(const GLubyte *token, GLuint swizzle[4]) -{ -   if (token[1] == 0) { -      /* single letter swizzle (scalar) */ -      if (token[0] == 'x') -         ASSIGN_4V(swizzle, 0, 0, 0, 0); -      else if (token[0] == 'y') -         ASSIGN_4V(swizzle, 1, 1, 1, 1); -      else if (token[0] == 'z') -         ASSIGN_4V(swizzle, 2, 2, 2, 2); -      else if (token[0] == 'w') -         ASSIGN_4V(swizzle, 3, 3, 3, 3); -      else -         return GL_FALSE; -   } -   else { -      /* 4-component swizzle (vector) */ -      GLint k; -      for (k = 0; k < 4 && token[k]; k++) { -         if (token[k] == 'x') -            swizzle[k] = 0; -         else if (token[k] == 'y') -            swizzle[k] = 1; -         else if (token[k] == 'z') -            swizzle[k] = 2; -         else if (token[k] == 'w') -            swizzle[k] = 3; -         else -            return GL_FALSE; -      } -      if (k != 4) -         return GL_FALSE; -   } -   return GL_TRUE; -} - - -static GLboolean -Parse_CondCodeMask(struct parse_state *parseState, -                   struct prog_dst_register *dstReg) -{ -   if (Parse_String(parseState, "EQ")) -      dstReg->CondMask = COND_EQ; -   else if (Parse_String(parseState, "GE")) -      dstReg->CondMask = COND_GE; -   else if (Parse_String(parseState, "GT")) -      dstReg->CondMask = COND_GT; -   else if (Parse_String(parseState, "LE")) -      dstReg->CondMask = COND_LE; -   else if (Parse_String(parseState, "LT")) -      dstReg->CondMask = COND_LT; -   else if (Parse_String(parseState, "NE")) -      dstReg->CondMask = COND_NE; -   else if (Parse_String(parseState, "TR")) -      dstReg->CondMask = COND_TR; -   else if (Parse_String(parseState, "FL")) -      dstReg->CondMask = COND_FL; -   else -      RETURN_ERROR1("Invalid condition code mask"); - -   /* look for optional .xyzw swizzle */ -   if (Parse_String(parseState, ".")) { -      GLubyte token[100]; -      GLuint swz[4]; - -      if (!Parse_Token(parseState, token))  /* get xyzw suffix */ -         RETURN_ERROR; - -      if (!Parse_SwizzleSuffix(token, swz)) -         RETURN_ERROR1("Invalid swizzle suffix"); - -      dstReg->CondSwizzle = MAKE_SWIZZLE4(swz[0], swz[1], swz[2], swz[3]); -   } - -   return GL_TRUE; -} - - -/** - * Parse a temporary register: Rnn or Hnn - */ -static GLboolean -Parse_TempReg(struct parse_state *parseState, GLint *tempRegNum) -{ -   GLubyte token[100]; - -   /* Should be 'R##' or 'H##' */ -   if (!Parse_Token(parseState, token)) -      RETURN_ERROR; -   if (token[0] != 'R' && token[0] != 'H') -      RETURN_ERROR1("Expected R## or H##"); - -   if (IsDigit(token[1])) { -      GLint reg = atoi((const char *) (token + 1)); -      if (token[0] == 'H') -         reg += 32; -      if (reg >= MAX_NV_FRAGMENT_PROGRAM_TEMPS) -         RETURN_ERROR1("Invalid temporary register name"); -      *tempRegNum = reg; -   } -   else { -      RETURN_ERROR1("Invalid temporary register name"); -   } - -   return GL_TRUE; -} - - -/** - * Parse a write-only dummy register: RC or HC. - */ -static GLboolean -Parse_DummyReg(struct parse_state *parseState, GLint *regNum) -{ -   if (Parse_String(parseState, "RC")) { -       *regNum = 0; -   } -   else if (Parse_String(parseState, "HC")) { -       *regNum = 1; -   } -   else { -      RETURN_ERROR1("Invalid write-only register name"); -   } - -   return GL_TRUE; -} - - -/** - * Parse a program local parameter register "p[##]" - */ -static GLboolean -Parse_ProgramParamReg(struct parse_state *parseState, GLint *regNum) -{ -   GLubyte token[100]; - -   if (!Parse_String(parseState, "p[")) -      RETURN_ERROR1("Expected p["); - -   if (!Parse_Token(parseState, token)) -      RETURN_ERROR; - -   if (IsDigit(token[0])) { -      /* a numbered program parameter register */ -      GLint reg = atoi((const char *) token); -      if (reg >= MAX_NV_FRAGMENT_PROGRAM_PARAMS) -         RETURN_ERROR1("Invalid constant program number"); -      *regNum = reg; -   } -   else { -      RETURN_ERROR; -   } - -   if (!Parse_String(parseState, "]")) -      RETURN_ERROR1("Expected ]"); - -   return GL_TRUE; -} - - -/** - * Parse f[name]  - fragment input register - */ -static GLboolean -Parse_FragReg(struct parse_state *parseState, GLint *tempRegNum) -{ -   GLubyte token[100]; -   GLint j; - -   /* Match 'f[' */ -   if (!Parse_String(parseState, "f[")) -      RETURN_ERROR1("Expected f["); - -   /* get <name> and look for match */ -   if (!Parse_Token(parseState, token)) { -      RETURN_ERROR; -   } -   for (j = 0; InputRegisters[j]; j++) { -      if (strcmp((const char *) token, InputRegisters[j]) == 0) { -         *tempRegNum = j; -         parseState->inputsRead |= (1 << j); -         break; -      } -   } -   if (!InputRegisters[j]) { -      /* unknown input register label */ -      RETURN_ERROR2("Invalid register name", token); -   } - -   /* Match '[' */ -   if (!Parse_String(parseState, "]")) -      RETURN_ERROR1("Expected ]"); - -   return GL_TRUE; -} - - -static GLboolean -Parse_OutputReg(struct parse_state *parseState, GLint *outputRegNum) -{ -   GLubyte token[100]; - -   /* Match "o[" */ -   if (!Parse_String(parseState, "o[")) -      RETURN_ERROR1("Expected o["); - -   /* Get output reg name */ -   if (!Parse_Token(parseState, token)) -      RETURN_ERROR; - -   /* try to match an output register name */ -   if (strcmp((char *) token, "COLR") == 0 || -       strcmp((char *) token, "COLH") == 0) { -      /* note that we don't distinguish between COLR and COLH */ -      *outputRegNum = FRAG_RESULT_COLOR; -      parseState->outputsWritten |= (1 << FRAG_RESULT_COLOR); -   } -   else if (strcmp((char *) token, "DEPR") == 0) { -      *outputRegNum = FRAG_RESULT_DEPTH; -      parseState->outputsWritten |= (1 << FRAG_RESULT_DEPTH); -   } -   else { -      RETURN_ERROR1("Invalid output register name"); -   } - -   /* Match ']' */ -   if (!Parse_String(parseState, "]")) -      RETURN_ERROR1("Expected ]"); - -   return GL_TRUE; -} - - -static GLboolean -Parse_MaskedDstReg(struct parse_state *parseState, -                   struct prog_dst_register *dstReg) -{ -   GLubyte token[100]; -   GLint idx; - -   /* Dst reg can be R<n>, H<n>, o[n], RC or HC */ -   if (!Peek_Token(parseState, token)) -      RETURN_ERROR; - -   if (strcmp((const char *) token, "RC") == 0 || -       strcmp((const char *) token, "HC") == 0) { -      /* a write-only register */ -      dstReg->File = PROGRAM_WRITE_ONLY; -      if (!Parse_DummyReg(parseState, &idx)) -         RETURN_ERROR; -      dstReg->Index = idx; -   } -   else if (token[0] == 'R' || token[0] == 'H') { -      /* a temporary register */ -      dstReg->File = PROGRAM_TEMPORARY; -      if (!Parse_TempReg(parseState, &idx)) -         RETURN_ERROR; -      dstReg->Index = idx; -   } -   else if (token[0] == 'o') { -      /* an output register */ -      dstReg->File = PROGRAM_OUTPUT; -      if (!Parse_OutputReg(parseState, &idx)) -         RETURN_ERROR; -      dstReg->Index = idx; -   } -   else { -      RETURN_ERROR1("Invalid destination register name"); -   } - -   /* Parse optional write mask */ -   if (Parse_String(parseState, ".")) { -      /* got a mask */ -      GLint k = 0; - -      if (!Parse_Token(parseState, token))  /* get xyzw writemask */ -         RETURN_ERROR; - -      dstReg->WriteMask = 0; - -      if (token[k] == 'x') { -         dstReg->WriteMask |= WRITEMASK_X; -         k++; -      } -      if (token[k] == 'y') { -         dstReg->WriteMask |= WRITEMASK_Y; -         k++; -      } -      if (token[k] == 'z') { -         dstReg->WriteMask |= WRITEMASK_Z; -         k++; -      } -      if (token[k] == 'w') { -         dstReg->WriteMask |= WRITEMASK_W; -         k++; -      } -      if (k == 0) { -         RETURN_ERROR1("Invalid writemask character"); -      } - -   } -   else { -      dstReg->WriteMask = WRITEMASK_XYZW; -   } - -   /* optional condition code mask */ -   if (Parse_String(parseState, "(")) { -      /* ("EQ" | "GE" | "GT" | "LE" | "LT" | "NE" | "TR" | "FL".x|y|z|w) */ -      /* ("EQ" | "GE" | "GT" | "LE" | "LT" | "NE" | "TR" | "FL".[xyzw]) */ -      if (!Parse_CondCodeMask(parseState, dstReg)) -         RETURN_ERROR; - -      if (!Parse_String(parseState, ")"))  /* consume ")" */ -         RETURN_ERROR1("Expected )"); - -      return GL_TRUE; -   } -   else { -      /* no cond code mask */ -      dstReg->CondMask = COND_TR; -      dstReg->CondSwizzle = SWIZZLE_NOOP; -      return GL_TRUE; -   } -} - - -/** - * Parse a vector source (register, constant, etc): - *   <vectorSrc>    ::= <absVectorSrc> - *                    | <baseVectorSrc> - *   <absVectorSrc> ::= <negate> "|" <baseVectorSrc> "|" - */ -static GLboolean -Parse_VectorSrc(struct parse_state *parseState, -                struct prog_src_register *srcReg) -{ -   GLfloat sign = 1.0F; -   GLubyte token[100]; -   GLint idx; -   GLuint negateBase, negateAbs; - -   /* -    * First, take care of +/- and absolute value stuff. -    */ -   if (Parse_String(parseState, "-")) -      sign = -1.0F; -   else if (Parse_String(parseState, "+")) -      sign = +1.0F; - -   if (Parse_String(parseState, "|")) { -      srcReg->Abs = GL_TRUE; -      negateAbs = (sign < 0.0F) ? NEGATE_XYZW : NEGATE_NONE; - -      if (Parse_String(parseState, "-")) -         negateBase = NEGATE_XYZW; -      else if (Parse_String(parseState, "+")) -         negateBase = NEGATE_NONE; -      else -         negateBase = NEGATE_NONE; -   } -   else { -      srcReg->Abs = GL_FALSE; -      negateAbs = NEGATE_NONE; -      negateBase = (sign < 0.0F) ? NEGATE_XYZW : NEGATE_NONE; -   } - -   srcReg->Negate = srcReg->Abs ? negateAbs : negateBase; - -   /* This should be the real src vector/register name */ -   if (!Peek_Token(parseState, token)) -      RETURN_ERROR; - -   /* Src reg can be Rn, Hn, f[n], p[n], a named parameter, a scalar -    * literal or vector literal. -    */ -   if (token[0] == 'R' || token[0] == 'H') { -      srcReg->File = PROGRAM_TEMPORARY; -      if (!Parse_TempReg(parseState, &idx)) -         RETURN_ERROR; -      srcReg->Index = idx; -   } -   else if (token[0] == 'f') { -      /* XXX this might be an identifier! */ -      srcReg->File = PROGRAM_INPUT; -      if (!Parse_FragReg(parseState, &idx)) -         RETURN_ERROR; -      srcReg->Index = idx; -   } -   else if (token[0] == 'p') { -      /* XXX this might be an identifier! */ -      srcReg->File = PROGRAM_LOCAL_PARAM; -      if (!Parse_ProgramParamReg(parseState, &idx)) -         RETURN_ERROR; -      srcReg->Index = idx; -   } -   else if (IsLetter(token[0])){ -      GLubyte ident[100]; -      GLint paramIndex; -      if (!Parse_Identifier(parseState, ident)) -         RETURN_ERROR; -      paramIndex = _mesa_lookup_parameter_index(parseState->parameters, -                                                -1, (const char *) ident); -      if (paramIndex < 0) { -         RETURN_ERROR2("Undefined constant or parameter: ", ident); -      } -      srcReg->File = PROGRAM_NAMED_PARAM; -      srcReg->Index = paramIndex;       -   } -   else if (IsDigit(token[0]) || token[0] == '-' || token[0] == '+' || token[0] == '.'){ -      /* literal scalar constant */ -      GLfloat values[4]; -      GLuint paramIndex; -      if (!Parse_ScalarConstant(parseState, values)) -         RETURN_ERROR; -      paramIndex = _mesa_add_unnamed_constant(parseState->parameters, -                                              (gl_constant_value *) values, -                                              4, NULL); -      srcReg->File = PROGRAM_NAMED_PARAM; -      srcReg->Index = paramIndex; -   } -   else if (token[0] == '{'){ -      /* literal vector constant */ -      GLfloat values[4]; -      GLuint paramIndex; -      (void) Parse_String(parseState, "{"); -      if (!Parse_VectorConstant(parseState, values)) -         RETURN_ERROR; -      paramIndex = _mesa_add_unnamed_constant(parseState->parameters, -                                              (gl_constant_value *) values, -                                              4, NULL); -      srcReg->File = PROGRAM_NAMED_PARAM; -      srcReg->Index = paramIndex;       -   } -   else { -      RETURN_ERROR2("Invalid source register name", token); -   } - -   /* init swizzle fields */ -   srcReg->Swizzle = SWIZZLE_NOOP; - -   /* Look for optional swizzle suffix */ -   if (Parse_String(parseState, ".")) { -      GLuint swz[4]; - -      if (!Parse_Token(parseState, token)) -         RETURN_ERROR; - -      if (!Parse_SwizzleSuffix(token, swz)) -         RETURN_ERROR1("Invalid swizzle suffix"); - -      srcReg->Swizzle = MAKE_SWIZZLE4(swz[0], swz[1], swz[2], swz[3]); -   } - -   /* Finish absolute value */ -   if (srcReg->Abs && !Parse_String(parseState, "|")) { -      RETURN_ERROR1("Expected |"); -   } - -   return GL_TRUE; -} - - -static GLboolean -Parse_ScalarSrcReg(struct parse_state *parseState, -                   struct prog_src_register *srcReg) -{ -   GLubyte token[100]; -   GLfloat sign = 1.0F; -   GLboolean needSuffix = GL_TRUE; -   GLint idx; -   GLuint negateBase, negateAbs; - -   /* -    * First, take care of +/- and absolute value stuff. -    */ -   if (Parse_String(parseState, "-")) -      sign = -1.0F; -   else if (Parse_String(parseState, "+")) -      sign = +1.0F; - -   if (Parse_String(parseState, "|")) { -      srcReg->Abs = GL_TRUE; -      negateAbs = (sign < 0.0F) ? NEGATE_XYZW : NEGATE_NONE; - -      if (Parse_String(parseState, "-")) -         negateBase = NEGATE_XYZW; -      else if (Parse_String(parseState, "+")) -         negateBase = NEGATE_NONE; -      else -         negateBase = NEGATE_NONE; -   } -   else { -      srcReg->Abs = GL_FALSE; -      negateAbs = NEGATE_NONE; -      negateBase = (sign < 0.0F) ? NEGATE_XYZW : NEGATE_NONE; -   } - -   srcReg->Negate = srcReg->Abs ? negateAbs : negateBase; - -   if (!Peek_Token(parseState, token)) -      RETURN_ERROR; - -   /* Src reg can be R<n>, H<n> or a named fragment attrib */ -   if (token[0] == 'R' || token[0] == 'H') { -      srcReg->File = PROGRAM_TEMPORARY; -      if (!Parse_TempReg(parseState, &idx)) -         RETURN_ERROR; -      srcReg->Index = idx; -   } -   else if (token[0] == 'f') { -      srcReg->File = PROGRAM_INPUT; -      if (!Parse_FragReg(parseState, &idx)) -         RETURN_ERROR; -      srcReg->Index = idx; -   } -   else if (token[0] == '{') { -      /* vector literal */ -      GLfloat values[4]; -      GLuint paramIndex; -      (void) Parse_String(parseState, "{"); -      if (!Parse_VectorConstant(parseState, values)) -         RETURN_ERROR; -      paramIndex = _mesa_add_unnamed_constant(parseState->parameters, -                                              (gl_constant_value *) values, -                                              4, NULL); -      srcReg->File = PROGRAM_NAMED_PARAM; -      srcReg->Index = paramIndex;       -   } -   else if (IsLetter(token[0])){ -      /* named param/constant */ -      GLubyte ident[100]; -      GLint paramIndex; -      if (!Parse_Identifier(parseState, ident)) -         RETURN_ERROR; -      paramIndex = _mesa_lookup_parameter_index(parseState->parameters, -                                                -1, (const char *) ident); -      if (paramIndex < 0) { -         RETURN_ERROR2("Undefined constant or parameter: ", ident); -      } -      srcReg->File = PROGRAM_NAMED_PARAM; -      srcReg->Index = paramIndex;       -   } -   else if (IsDigit(token[0])) { -      /* scalar literal */ -      GLfloat values[4]; -      GLuint paramIndex; -      if (!Parse_ScalarConstant(parseState, values)) -         RETURN_ERROR; -      paramIndex = _mesa_add_unnamed_constant(parseState->parameters, -                                              (gl_constant_value *) values, -                                              4, NULL); -      srcReg->Index = paramIndex;       -      srcReg->File = PROGRAM_NAMED_PARAM; -      needSuffix = GL_FALSE; -   } -   else { -      RETURN_ERROR2("Invalid scalar source argument", token); -   } - -   srcReg->Swizzle = 0; -   if (needSuffix) { -      /* parse .[xyzw] suffix */ -      if (!Parse_String(parseState, ".")) -         RETURN_ERROR1("Expected ."); - -      if (!Parse_Token(parseState, token)) -         RETURN_ERROR; - -      if (token[0] == 'x' && token[1] == 0) { -         srcReg->Swizzle = 0; -      } -      else if (token[0] == 'y' && token[1] == 0) { -         srcReg->Swizzle = 1; -      } -      else if (token[0] == 'z' && token[1] == 0) { -         srcReg->Swizzle = 2; -      } -      else if (token[0] == 'w' && token[1] == 0) { -         srcReg->Swizzle = 3; -      } -      else { -         RETURN_ERROR1("Invalid scalar source suffix"); -      } -   } - -   /* Finish absolute value */ -   if (srcReg->Abs && !Parse_String(parseState, "|")) { -      RETURN_ERROR1("Expected |"); -   } - -   return GL_TRUE; -} - - -static GLboolean -Parse_PrintInstruction(struct parse_state *parseState, -                       struct prog_instruction *inst) -{ -   const GLubyte *str; -   GLubyte *msg; -   GLuint len; -   GLint idx; - -   /* The first argument is a literal string 'just like this' */ -   if (!Parse_String(parseState, "'")) -      RETURN_ERROR1("Expected '"); - -   str = parseState->pos; -   for (len = 0; str[len] != '\''; len++) /* find closing quote */ -      ; -   parseState->pos += len + 1; -   msg = malloc(len + 1); - -   memcpy(msg, str, len); -   msg[len] = 0; -   inst->Data = msg; - -   if (Parse_String(parseState, ",")) { -      /* got an optional register to print */ -      GLubyte token[100]; -      GetToken(parseState, token); -      if (token[0] == 'o') { -         /* dst reg */ -         if (!Parse_OutputReg(parseState, &idx)) -            RETURN_ERROR; -	 inst->SrcReg[0].Index = idx; -         inst->SrcReg[0].File = PROGRAM_OUTPUT; -      } -      else { -         /* src reg */ -         if (!Parse_VectorSrc(parseState, &inst->SrcReg[0])) -            RETURN_ERROR; -      } -   } -   else { -      inst->SrcReg[0].File = PROGRAM_UNDEFINED; -   } - -   inst->SrcReg[0].Swizzle = SWIZZLE_NOOP; -   inst->SrcReg[0].Abs = GL_FALSE; -   inst->SrcReg[0].Negate = NEGATE_NONE; - -   return GL_TRUE; -} - - -static GLboolean -Parse_InstructionSequence(struct parse_state *parseState, -                          struct prog_instruction program[]) -{ -   while (1) { -      struct prog_instruction *inst = program + parseState->numInst; -      struct instruction_pattern instMatch; -      GLubyte token[100]; - -      /* Initialize the instruction */ -      _mesa_init_instructions(inst, 1); - -      /* special instructions */ -      if (Parse_String(parseState, "DEFINE")) { -         GLubyte id[100]; -         GLfloat value[7];  /* yes, 7 to be safe */ -         if (!Parse_Identifier(parseState, id)) -            RETURN_ERROR; -         /* XXX make sure id is not a reserved identifer, like R9 */ -         if (!Parse_String(parseState, "=")) -            RETURN_ERROR1("Expected ="); -         if (!Parse_VectorOrScalarConstant(parseState, value)) -            RETURN_ERROR; -         if (!Parse_String(parseState, ";")) -            RETURN_ERROR1("Expected ;"); -         if (_mesa_lookup_parameter_index(parseState->parameters, -                                          -1, (const char *) id) >= 0) { -            RETURN_ERROR2(id, "already defined"); -         } -         _mesa_add_named_parameter(parseState->parameters, -                                   (const char *) id, -                                   (gl_constant_value *) value); -      } -      else if (Parse_String(parseState, "DECLARE")) { -         GLubyte id[100]; -         GLfloat value[7] = {0, 0, 0, 0, 0, 0, 0};  /* yes, to be safe */ -         if (!Parse_Identifier(parseState, id)) -            RETURN_ERROR; -         /* XXX make sure id is not a reserved identifer, like R9 */ -         if (Parse_String(parseState, "=")) { -            if (!Parse_VectorOrScalarConstant(parseState, value)) -               RETURN_ERROR; -         } -         if (!Parse_String(parseState, ";")) -            RETURN_ERROR1("Expected ;"); -         if (_mesa_lookup_parameter_index(parseState->parameters, -                                          -1, (const char *) id) >= 0) { -            RETURN_ERROR2(id, "already declared"); -         } -         _mesa_add_named_parameter(parseState->parameters, -                                   (const char *) id, -                                   (gl_constant_value *) value); -      } -      else if (Parse_String(parseState, "END")) { -         inst->Opcode = OPCODE_END; -         parseState->numInst++; -         if (Parse_Token(parseState, token)) { -            RETURN_ERROR1("Code after END opcode."); -         } -         break; -      } -      else { -         /* general/arithmetic instruction */ - -         /* get token */ -         if (!Parse_Token(parseState, token)) { -            RETURN_ERROR1("Missing END instruction."); -         } - -         /* try to find matching instuction */ -         instMatch = MatchInstruction(token); -         if (instMatch.opcode >= MAX_OPCODE) { -            /* bad instruction name */ -            RETURN_ERROR2("Unexpected token: ", token); -         } - -         inst->Opcode = instMatch.opcode; -         inst->Precision = instMatch.suffixes & (_R | _H | _X); -         inst->SaturateMode = (instMatch.suffixes & (_S)) -            ? SATURATE_ZERO_ONE : SATURATE_OFF; -         inst->CondUpdate = (instMatch.suffixes & (_C)) ? GL_TRUE : GL_FALSE; - -         /* -          * parse the input and output operands -          */ -         if (instMatch.outputs == OUTPUT_S || instMatch.outputs == OUTPUT_V) { -            if (!Parse_MaskedDstReg(parseState, &inst->DstReg)) -               RETURN_ERROR; -            if (!Parse_String(parseState, ",")) -               RETURN_ERROR1("Expected ,"); -         } -         else if (instMatch.outputs == OUTPUT_NONE) { -            if (instMatch.opcode == OPCODE_KIL_NV) { -               /* This is a little weird, the cond code info is in -                * the dest register. -                */ -               if (!Parse_CondCodeMask(parseState, &inst->DstReg)) -                  RETURN_ERROR; -            } -            else { -               ASSERT(instMatch.opcode == OPCODE_PRINT); -            } -         } - -         if (instMatch.inputs == INPUT_1V) { -            if (!Parse_VectorSrc(parseState, &inst->SrcReg[0])) -               RETURN_ERROR; -         } -         else if (instMatch.inputs == INPUT_2V) { -            if (!Parse_VectorSrc(parseState, &inst->SrcReg[0])) -               RETURN_ERROR; -            if (!Parse_String(parseState, ",")) -               RETURN_ERROR1("Expected ,"); -            if (!Parse_VectorSrc(parseState, &inst->SrcReg[1])) -               RETURN_ERROR; -         } -         else if (instMatch.inputs == INPUT_3V) { -            if (!Parse_VectorSrc(parseState, &inst->SrcReg[0])) -               RETURN_ERROR; -            if (!Parse_String(parseState, ",")) -               RETURN_ERROR1("Expected ,"); -            if (!Parse_VectorSrc(parseState, &inst->SrcReg[1])) -               RETURN_ERROR; -            if (!Parse_String(parseState, ",")) -               RETURN_ERROR1("Expected ,"); -            if (!Parse_VectorSrc(parseState, &inst->SrcReg[2])) -               RETURN_ERROR; -         } -         else if (instMatch.inputs == INPUT_1S) { -            if (!Parse_ScalarSrcReg(parseState, &inst->SrcReg[0])) -               RETURN_ERROR; -         } -         else if (instMatch.inputs == INPUT_2S) { -            if (!Parse_ScalarSrcReg(parseState, &inst->SrcReg[0])) -               RETURN_ERROR; -            if (!Parse_String(parseState, ",")) -               RETURN_ERROR1("Expected ,"); -            if (!Parse_ScalarSrcReg(parseState, &inst->SrcReg[1])) -               RETURN_ERROR; -         } -         else if (instMatch.inputs == INPUT_CC) { -            /* XXX to-do */ -         } -         else if (instMatch.inputs == INPUT_1V_T) { -	    GLubyte unit, idx; -            if (!Parse_VectorSrc(parseState, &inst->SrcReg[0])) -               RETURN_ERROR; -            if (!Parse_String(parseState, ",")) -               RETURN_ERROR1("Expected ,"); -            if (!Parse_TextureImageId(parseState, &unit, &idx)) -               RETURN_ERROR; -	    inst->TexSrcUnit = unit; -	    inst->TexSrcTarget = idx; -         } -         else if (instMatch.inputs == INPUT_3V_T) { -	    GLubyte unit, idx; -            if (!Parse_VectorSrc(parseState, &inst->SrcReg[0])) -               RETURN_ERROR; -            if (!Parse_String(parseState, ",")) -               RETURN_ERROR1("Expected ,"); -            if (!Parse_VectorSrc(parseState, &inst->SrcReg[1])) -               RETURN_ERROR; -            if (!Parse_String(parseState, ",")) -               RETURN_ERROR1("Expected ,"); -            if (!Parse_VectorSrc(parseState, &inst->SrcReg[2])) -               RETURN_ERROR; -            if (!Parse_String(parseState, ",")) -               RETURN_ERROR1("Expected ,"); -            if (!Parse_TextureImageId(parseState, &unit, &idx)) -               RETURN_ERROR; -	    inst->TexSrcUnit = unit; -	    inst->TexSrcTarget = idx; -         } -         else if (instMatch.inputs == INPUT_1V_S) { -            if (!Parse_PrintInstruction(parseState, inst)) -               RETURN_ERROR; -         } - -         /* end of statement semicolon */ -         if (!Parse_String(parseState, ";")) -            RETURN_ERROR1("Expected ;"); - -         parseState->numInst++; - -         if (parseState->numInst >= MAX_NV_FRAGMENT_PROGRAM_INSTRUCTIONS) -            RETURN_ERROR1("Program too long"); -      } -   } -   return GL_TRUE; -} - - - -/** - * Parse/compile the 'str' returning the compiled 'program'. - * ctx->Program.ErrorPos will be -1 if successful.  Otherwise, ErrorPos - * indicates the position of the error in 'str'. - */ -void -_mesa_parse_nv_fragment_program(struct gl_context *ctx, GLenum dstTarget, -                                const GLubyte *str, GLsizei len, -                                struct gl_fragment_program *program) -{ -   struct parse_state parseState; -   struct prog_instruction instBuffer[MAX_NV_FRAGMENT_PROGRAM_INSTRUCTIONS]; -   struct prog_instruction *newInst; -   GLenum target; -   GLubyte *programString; - -   /* Make a null-terminated copy of the program string */ -   programString = malloc(len + 1); -   if (!programString) { -      _mesa_error(ctx, GL_OUT_OF_MEMORY, "glLoadProgramNV"); -      return; -   } -   memcpy(programString, str, len); -   programString[len] = 0; - -   /* Get ready to parse */ -   memset(&parseState, 0, sizeof(struct parse_state)); -   parseState.ctx = ctx; -   parseState.start = programString; -   parseState.program = program; -   parseState.numInst = 0; -   parseState.curLine = programString; -   parseState.parameters = _mesa_new_parameter_list(); - -   /* Reset error state */ -   _mesa_set_program_error(ctx, -1, NULL); - -   /* check the program header */ -   if (strncmp((const char *) programString, "!!FP1.0", 7) == 0) { -      target = GL_FRAGMENT_PROGRAM_NV; -      parseState.pos = programString + 7; -   } -   else if (strncmp((const char *) programString, "!!FCP1.0", 8) == 0) { -      /* fragment / register combiner program - not supported */ -      _mesa_set_program_error(ctx, 0, "Invalid fragment program header"); -      _mesa_error(ctx, GL_INVALID_OPERATION, "glLoadProgramNV(bad header)"); -      return; -   } -   else { -      /* invalid header */ -      _mesa_set_program_error(ctx, 0, "Invalid fragment program header"); -      _mesa_error(ctx, GL_INVALID_OPERATION, "glLoadProgramNV(bad header)"); -      return; -   } - -   /* make sure target and header match */ -   if (target != dstTarget) { -      _mesa_error(ctx, GL_INVALID_OPERATION, -                  "glLoadProgramNV(target mismatch 0x%x != 0x%x)", -                  target, dstTarget); -      return; -   } - -   if (Parse_InstructionSequence(&parseState, instBuffer)) { -      GLuint u; -      /* successful parse! */ - -      if (parseState.outputsWritten == 0) { -         /* must write at least one output! */ -         _mesa_error(ctx, GL_INVALID_OPERATION, -                     "Invalid fragment program - no outputs written."); -         return; -      } - -      /* copy the compiled instructions */ -      assert(parseState.numInst <= MAX_NV_FRAGMENT_PROGRAM_INSTRUCTIONS); -      newInst = _mesa_alloc_instructions(parseState.numInst); -      if (!newInst) { -         _mesa_error(ctx, GL_OUT_OF_MEMORY, "glLoadProgramNV"); -         return;  /* out of memory */ -      } -      _mesa_copy_instructions(newInst, instBuffer, parseState.numInst); - -      /* install the program */ -      program->Base.Target = target; -      free(program->Base.String); -      program->Base.String = programString; -      program->Base.Format = GL_PROGRAM_FORMAT_ASCII_ARB; -      free(program->Base.Instructions); -      program->Base.Instructions = newInst; -      program->Base.NumInstructions = parseState.numInst; -      program->Base.InputsRead = parseState.inputsRead; -      program->Base.OutputsWritten = parseState.outputsWritten; -      for (u = 0; u < ctx->Const.MaxTextureImageUnits; u++) -         program->Base.TexturesUsed[u] = parseState.texturesUsed[u]; - -      /* save program parameters */ -      program->Base.Parameters = parseState.parameters; - -      /* allocate registers for declared program parameters */ -#if 00 -      _mesa_assign_program_registers(&(program->SymbolTable)); -#endif - -#ifdef DEBUG_foo -      printf("--- glLoadProgramNV(%d) result ---\n", program->Base.Id); -      _mesa_fprint_program_opt(stdout, &program->Base, PROG_PRINT_NV, 0); -      printf("----------------------------------\n"); -#endif -   } -   else { -      /* Error! */ -      _mesa_error(ctx, GL_INVALID_OPERATION, "glLoadProgramNV"); -      /* NOTE: _mesa_set_program_error would have been called already */ -   } -} - - -const char * -_mesa_nv_fragment_input_register_name(GLuint i) -{ -   ASSERT(i < MAX_NV_FRAGMENT_PROGRAM_INPUTS); -   return InputRegisters[i]; -} - diff --git a/mesalib/src/mesa/program/nvfragparse.h b/mesalib/src/mesa/program/nvfragparse.h deleted file mode 100644 index 088e7527d..000000000 --- a/mesalib/src/mesa/program/nvfragparse.h +++ /dev/null @@ -1,47 +0,0 @@ - -/* - * Mesa 3-D graphics library - * Version:  5.1 - * - * Copyright (C) 1999-2002  Brian Paul   All Rights Reserved. - * - * Permission is hereby granted, free of charge, to any person obtaining a - * copy of this software and associated documentation files (the "Software"), - * to deal in the Software without restriction, including without limitation - * the rights to use, copy, modify, merge, publish, distribute, sublicense, - * and/or sell copies of the Software, and to permit persons to whom the - * Software is furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included - * in all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS - * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL - * BRIAN PAUL BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN - * AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN - * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - * - * Authors: - *    Brian Paul - */ - - -#ifndef NVFRAGPARSE_H -#define NVFRAGPARSE_H - -#include "main/glheader.h" - -struct gl_context; -struct gl_fragment_program; - -extern void -_mesa_parse_nv_fragment_program(struct gl_context *ctx, GLenum target, -                                const GLubyte *str, GLsizei len, -                                struct gl_fragment_program *program); - - -extern const char * -_mesa_nv_fragment_input_register_name(GLuint i); - -#endif diff --git a/mesalib/src/mesa/program/nvvertparse.c b/mesalib/src/mesa/program/nvvertparse.c deleted file mode 100644 index 6272c2f7f..000000000 --- a/mesalib/src/mesa/program/nvvertparse.c +++ /dev/null @@ -1,1456 +0,0 @@ -/* - * Mesa 3-D graphics library - * Version:  6.5.2 - * - * Copyright (C) 1999-2006  Brian Paul   All Rights Reserved. - * - * Permission is hereby granted, free of charge, to any person obtaining a - * copy of this software and associated documentation files (the "Software"), - * to deal in the Software without restriction, including without limitation - * the rights to use, copy, modify, merge, publish, distribute, sublicense, - * and/or sell copies of the Software, and to permit persons to whom the - * Software is furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included - * in all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS - * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL - * BRIAN PAUL BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN - * AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN - * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - */ - -/** - * \file nvvertparse.c - * NVIDIA vertex program parser. - * \author Brian Paul - */ - -/* - * Regarding GL_NV_vertex_program, GL_NV_vertex_program1_1: - * - * Portions of this software may use or implement intellectual - * property owned and licensed by NVIDIA Corporation. NVIDIA disclaims - * any and all warranties with respect to such intellectual property, - * including any use thereof or modifications thereto. - */ - -#include "main/glheader.h" -#include "main/context.h" -#include "main/imports.h" -#include "main/nvprogram.h" -#include "nvvertparse.h" -#include "prog_instruction.h" -#include "prog_parameter.h" -#include "prog_print.h" -#include "program.h" - - -/** - * Current parsing state.  This structure is passed among the parsing - * functions and keeps track of the current parser position and various - * program attributes. - */ -struct parse_state { -   struct gl_context *ctx; -   const GLubyte *start; -   const GLubyte *pos; -   const GLubyte *curLine; -   GLboolean isStateProgram; -   GLboolean isPositionInvariant; -   GLboolean isVersion1_1; -   GLbitfield inputsRead; -   GLbitfield outputsWritten; -   GLboolean anyProgRegsWritten; -   GLboolean indirectRegisterFiles; -   GLuint numInst;                 /* number of instructions parsed */ -}; - - -/* - * Called whenever we find an error during parsing. - */ -static void -record_error(struct parse_state *parseState, const char *msg, int lineNo) -{ -#ifdef DEBUG -   GLint line, column; -   const GLubyte *lineStr; -   lineStr = _mesa_find_line_column(parseState->start, -                                    parseState->pos, &line, &column); -   _mesa_debug(parseState->ctx, -               "nvfragparse.c(%d): line %d, column %d:%s (%s)\n", -               lineNo, line, column, (char *) lineStr, msg); -   free((void *) lineStr); -#else -   (void) lineNo; -#endif - -   /* Check that no error was already recorded.  Only record the first one. */ -   if (parseState->ctx->Program.ErrorString[0] == 0) { -      _mesa_set_program_error(parseState->ctx, -                              parseState->pos - parseState->start, -                              msg); -   } -} - - -#define RETURN_ERROR							\ -do {									\ -   record_error(parseState, "Unexpected end of input.", __LINE__);	\ -   return GL_FALSE;							\ -} while(0) - -#define RETURN_ERROR1(msg)						\ -do {									\ -   record_error(parseState, msg, __LINE__);				\ -   return GL_FALSE;							\ -} while(0) - -#define RETURN_ERROR2(msg1, msg2)					\ -do {									\ -   char err[1000];							\ -   sprintf(err, "%s %s", msg1, msg2);				\ -   record_error(parseState, err, __LINE__);				\ -   return GL_FALSE;							\ -} while(0) - - - - - -static GLboolean IsLetter(GLubyte b) -{ -   return (b >= 'a' && b <= 'z') || (b >= 'A' && b <= 'Z'); -} - - -static GLboolean IsDigit(GLubyte b) -{ -   return b >= '0' && b <= '9'; -} - - -static GLboolean IsWhitespace(GLubyte b) -{ -   return b == ' ' || b == '\t' || b == '\n' || b == '\r'; -} - - -/** - * Starting at 'str' find the next token.  A token can be an integer, - * an identifier or punctuation symbol. - * \return <= 0 we found an error, else, return number of characters parsed. - */ -static GLint -GetToken(struct parse_state *parseState, GLubyte *token) -{ -   const GLubyte *str = parseState->pos; -   GLint i = 0, j = 0; - -   token[0] = 0; - -   /* skip whitespace and comments */ -   while (str[i] && (IsWhitespace(str[i]) || str[i] == '#')) { -      if (str[i] == '#') { -         /* skip comment */ -         while (str[i] && (str[i] != '\n' && str[i] != '\r')) { -            i++; -         } -         if (str[i] == '\n' || str[i] == '\r') -            parseState->curLine = str + i + 1; -      } -      else { -         /* skip whitespace */ -         if (str[i] == '\n' || str[i] == '\r') -            parseState->curLine = str + i + 1; -         i++; -      } -   } - -   if (str[i] == 0) -      return -i; - -   /* try matching an integer */ -   while (str[i] && IsDigit(str[i])) { -      token[j++] = str[i++]; -   } -   if (j > 0 || !str[i]) { -      token[j] = 0; -      return i; -   } - -   /* try matching an identifier */ -   if (IsLetter(str[i])) { -      while (str[i] && (IsLetter(str[i]) || IsDigit(str[i]))) { -         token[j++] = str[i++]; -      } -      token[j] = 0; -      return i; -   } - -   /* punctuation character */ -   if (str[i]) { -      token[0] = str[i++]; -      token[1] = 0; -      return i; -   } - -   /* end of input */ -   token[0] = 0; -   return i; -} - - -/** - * Get next token from input stream and increment stream pointer past token. - */ -static GLboolean -Parse_Token(struct parse_state *parseState, GLubyte *token) -{ -   GLint i; -   i = GetToken(parseState, token); -   if (i <= 0) { -      parseState->pos += (-i); -      return GL_FALSE; -   } -   parseState->pos += i; -   return GL_TRUE; -} - - -/** - * Get next token from input stream but don't increment stream pointer. - */ -static GLboolean -Peek_Token(struct parse_state *parseState, GLubyte *token) -{ -   GLint i, len; -   i = GetToken(parseState, token); -   if (i <= 0) { -      parseState->pos += (-i); -      return GL_FALSE; -   } -   len = (GLint) strlen((const char *) token); -   parseState->pos += (i - len); -   return GL_TRUE; -} - - -/** - * Try to match 'pattern' as the next token after any whitespace/comments. - * Advance the current parsing position only if we match the pattern. - * \return GL_TRUE if pattern is matched, GL_FALSE otherwise. - */ -static GLboolean -Parse_String(struct parse_state *parseState, const char *pattern) -{ -   const GLubyte *m; -   GLint i; - -   /* skip whitespace and comments */ -   while (IsWhitespace(*parseState->pos) || *parseState->pos == '#') { -      if (*parseState->pos == '#') { -         while (*parseState->pos && (*parseState->pos != '\n' && *parseState->pos != '\r')) { -            parseState->pos += 1; -         } -         if (*parseState->pos == '\n' || *parseState->pos == '\r') -            parseState->curLine = parseState->pos + 1; -      } -      else { -         /* skip whitespace */ -         if (*parseState->pos == '\n' || *parseState->pos == '\r') -            parseState->curLine = parseState->pos + 1; -         parseState->pos += 1; -      } -   } - -   /* Try to match the pattern */ -   m = parseState->pos; -   for (i = 0; pattern[i]; i++) { -      if (*m != (GLubyte) pattern[i]) -         return GL_FALSE; -      m += 1; -   } -   parseState->pos = m; - -   return GL_TRUE; /* success */ -} - - -/**********************************************************************/ - -static const char *InputRegisters[MAX_NV_VERTEX_PROGRAM_INPUTS + 1] = { -   "OPOS", "WGHT", "NRML", "COL0", "COL1", "FOGC", "6", "7", -   "TEX0", "TEX1", "TEX2", "TEX3", "TEX4", "TEX5", "TEX6", "TEX7", NULL -}; - -static const char *OutputRegisters[MAX_NV_VERTEX_PROGRAM_OUTPUTS + 1] = { -   "HPOS", "COL0", "COL1", "FOGC",  -   "TEX0", "TEX1", "TEX2", "TEX3", "TEX4", "TEX5", "TEX6", "TEX7",  -   "PSIZ", "BFC0", "BFC1", NULL -}; - - - -/** - * Parse a temporary register: Rnn - */ -static GLboolean -Parse_TempReg(struct parse_state *parseState, GLint *tempRegNum) -{ -   GLubyte token[100]; - -   /* Should be 'R##' */ -   if (!Parse_Token(parseState, token)) -      RETURN_ERROR; -   if (token[0] != 'R') -      RETURN_ERROR1("Expected R##"); - -   if (IsDigit(token[1])) { -      GLint reg = atoi((char *) (token + 1)); -      if (reg >= MAX_NV_VERTEX_PROGRAM_TEMPS) -         RETURN_ERROR1("Bad temporary register name"); -      *tempRegNum = reg; -   } -   else { -      RETURN_ERROR1("Bad temporary register name"); -   } - -   return GL_TRUE; -} - - -/** - * Parse address register "A0.x" - */ -static GLboolean -Parse_AddrReg(struct parse_state *parseState) -{ -   /* match 'A0' */ -   if (!Parse_String(parseState, "A0")) -      RETURN_ERROR; - -   /* match '.' */ -   if (!Parse_String(parseState, ".")) -      RETURN_ERROR; - -   /* match 'x' */ -   if (!Parse_String(parseState, "x")) -      RETURN_ERROR; - -   return GL_TRUE; -} - - -/** - * Parse absolute program parameter register "c[##]" - */ -static GLboolean -Parse_AbsParamReg(struct parse_state *parseState, GLint *regNum) -{ -   GLubyte token[100]; - -   if (!Parse_String(parseState, "c")) -      RETURN_ERROR; - -   if (!Parse_String(parseState, "[")) -      RETURN_ERROR; - -   if (!Parse_Token(parseState, token)) -      RETURN_ERROR; - -   if (IsDigit(token[0])) { -      /* a numbered program parameter register */ -      GLint reg = atoi((char *) token); -      if (reg >= MAX_NV_VERTEX_PROGRAM_PARAMS) -         RETURN_ERROR1("Bad program parameter number"); -      *regNum = reg; -   } -   else { -      RETURN_ERROR; -   } - -   if (!Parse_String(parseState, "]")) -      RETURN_ERROR; - -   return GL_TRUE; -} - - -static GLboolean -Parse_ParamReg(struct parse_state *parseState, struct prog_src_register *srcReg) -{ -   GLubyte token[100]; - -   if (!Parse_String(parseState, "c")) -      RETURN_ERROR; - -   if (!Parse_String(parseState, "[")) -      RETURN_ERROR; - -   if (!Peek_Token(parseState, token)) -      RETURN_ERROR; - -   if (IsDigit(token[0])) { -      /* a numbered program parameter register */ -      GLint reg; -      (void) Parse_Token(parseState, token); -      reg = atoi((char *) token); -      if (reg >= MAX_NV_VERTEX_PROGRAM_PARAMS) -         RETURN_ERROR1("Bad program parameter number"); -      srcReg->File = PROGRAM_ENV_PARAM; -      srcReg->Index = reg; -   } -   else if (strcmp((const char *) token, "A0") == 0) { -      /* address register "A0.x" */ -      if (!Parse_AddrReg(parseState)) -         RETURN_ERROR; - -      srcReg->RelAddr = GL_TRUE; -      srcReg->File = PROGRAM_ENV_PARAM; -      parseState->indirectRegisterFiles |= (1 << srcReg->File); -      /* Look for +/-N offset */ -      if (!Peek_Token(parseState, token)) -         RETURN_ERROR; - -      if (token[0] == '-' || token[0] == '+') { -         const GLubyte sign = token[0]; -         (void) Parse_Token(parseState, token); /* consume +/- */ - -         /* an integer should be next */ -         if (!Parse_Token(parseState, token)) -            RETURN_ERROR; - -         if (IsDigit(token[0])) { -            const GLint k = atoi((char *) token); -            if (sign == '-') { -               if (k > 64) -                  RETURN_ERROR1("Bad address offset"); -               srcReg->Index = -k; -            } -            else { -               if (k > 63) -                  RETURN_ERROR1("Bad address offset"); -               srcReg->Index = k; -            } -         } -         else { -            RETURN_ERROR; -         } -      } -      else { -         /* probably got a ']', catch it below */ -      } -   } -   else { -      RETURN_ERROR; -   } - -   /* Match closing ']' */ -   if (!Parse_String(parseState, "]")) -      RETURN_ERROR; - -   return GL_TRUE; -} - - -/** - * Parse v[#] or v[<name>] - */ -static GLboolean -Parse_AttribReg(struct parse_state *parseState, GLint *tempRegNum) -{ -   GLubyte token[100]; -   GLint j; - -   /* Match 'v' */ -   if (!Parse_String(parseState, "v")) -      RETURN_ERROR; - -   /* Match '[' */ -   if (!Parse_String(parseState, "[")) -      RETURN_ERROR; - -   /* match number or named register */ -   if (!Parse_Token(parseState, token)) -      RETURN_ERROR; - -   if (parseState->isStateProgram && token[0] != '0') -      RETURN_ERROR1("Only v[0] accessible in vertex state programs"); - -   if (IsDigit(token[0])) { -      GLint reg = atoi((char *) token); -      if (reg >= MAX_NV_VERTEX_PROGRAM_INPUTS) -         RETURN_ERROR1("Bad vertex attribute register name"); -      *tempRegNum = reg; -   } -   else { -      for (j = 0; InputRegisters[j]; j++) { -         if (strcmp((const char *) token, InputRegisters[j]) == 0) { -            *tempRegNum = j; -            break; -         } -      } -      if (!InputRegisters[j]) { -         /* unknown input register label */ -         RETURN_ERROR2("Bad register name", token); -      } -   } - -   /* Match '[' */ -   if (!Parse_String(parseState, "]")) -      RETURN_ERROR; - -   return GL_TRUE; -} - - -static GLboolean -Parse_OutputReg(struct parse_state *parseState, GLint *outputRegNum) -{ -   GLubyte token[100]; -   GLint start, j; - -   /* Match 'o' */ -   if (!Parse_String(parseState, "o")) -      RETURN_ERROR; - -   /* Match '[' */ -   if (!Parse_String(parseState, "[")) -      RETURN_ERROR; - -   /* Get output reg name */ -   if (!Parse_Token(parseState, token)) -      RETURN_ERROR; - -   if (parseState->isPositionInvariant) -      start = 1; /* skip HPOS register name */ -   else -      start = 0; - -   /* try to match an output register name */ -   for (j = start; OutputRegisters[j]; j++) { -      if (strcmp((const char *) token, OutputRegisters[j]) == 0) { -         *outputRegNum = j; -         break; -      } -   } -   if (!OutputRegisters[j]) -      RETURN_ERROR1("Unrecognized output register name"); - -   /* Match ']' */ -   if (!Parse_String(parseState, "]")) -      RETURN_ERROR1("Expected ]"); - -   return GL_TRUE; -} - - -static GLboolean -Parse_MaskedDstReg(struct parse_state *parseState, struct prog_dst_register *dstReg) -{ -   GLubyte token[100]; -   GLint idx; - -   /* Dst reg can be R<n> or o[n] */ -   if (!Peek_Token(parseState, token)) -      RETURN_ERROR; - -   if (token[0] == 'R') { -      /* a temporary register */ -      dstReg->File = PROGRAM_TEMPORARY; -      if (!Parse_TempReg(parseState, &idx)) -         RETURN_ERROR; -      dstReg->Index = idx; -   } -   else if (!parseState->isStateProgram && token[0] == 'o') { -      /* an output register */ -      dstReg->File = PROGRAM_OUTPUT; -      if (!Parse_OutputReg(parseState, &idx)) -         RETURN_ERROR; -      dstReg->Index = idx; -   } -   else if (parseState->isStateProgram && token[0] == 'c' && -            parseState->isStateProgram) { -      /* absolute program parameter register */ -      /* Only valid for vertex state programs */ -      dstReg->File = PROGRAM_ENV_PARAM; -      if (!Parse_AbsParamReg(parseState, &idx)) -         RETURN_ERROR; -      dstReg->Index = idx; -   } -   else { -      RETURN_ERROR1("Bad destination register name"); -   } - -   /* Parse optional write mask */ -   if (!Peek_Token(parseState, token)) -      RETURN_ERROR; - -   if (token[0] == '.') { -      /* got a mask */ -      GLint k = 0; - -      if (!Parse_String(parseState, ".")) -         RETURN_ERROR; - -      if (!Parse_Token(parseState, token)) -         RETURN_ERROR; - -      dstReg->WriteMask = 0; - -      if (token[k] == 'x') { -         dstReg->WriteMask |= WRITEMASK_X; -         k++; -      } -      if (token[k] == 'y') { -         dstReg->WriteMask |= WRITEMASK_Y; -         k++; -      } -      if (token[k] == 'z') { -         dstReg->WriteMask |= WRITEMASK_Z; -         k++; -      } -      if (token[k] == 'w') { -         dstReg->WriteMask |= WRITEMASK_W; -         k++; -      } -      if (k == 0) { -         RETURN_ERROR1("Bad writemask character"); -      } -      return GL_TRUE; -   } -   else { -      dstReg->WriteMask = WRITEMASK_XYZW; -      return GL_TRUE; -   } -} - - -static GLboolean -Parse_SwizzleSrcReg(struct parse_state *parseState, struct prog_src_register *srcReg) -{ -   GLubyte token[100]; -   GLint idx; - -   srcReg->RelAddr = GL_FALSE; - -   /* check for '-' */ -   if (!Peek_Token(parseState, token)) -      RETURN_ERROR; -   if (token[0] == '-') { -      (void) Parse_String(parseState, "-"); -      srcReg->Negate = NEGATE_XYZW; -      if (!Peek_Token(parseState, token)) -         RETURN_ERROR; -   } -   else { -      srcReg->Negate = NEGATE_NONE; -   } - -   /* Src reg can be R<n>, c[n], c[n +/- offset], or a named vertex attrib */ -   if (token[0] == 'R') { -      srcReg->File = PROGRAM_TEMPORARY; -      if (!Parse_TempReg(parseState, &idx)) -         RETURN_ERROR; -      srcReg->Index = idx; -   } -   else if (token[0] == 'c') { -      if (!Parse_ParamReg(parseState, srcReg)) -         RETURN_ERROR; -   } -   else if (token[0] == 'v') { -      srcReg->File = PROGRAM_INPUT; -      if (!Parse_AttribReg(parseState, &idx)) -         RETURN_ERROR; -      srcReg->Index = idx; -   } -   else { -      RETURN_ERROR2("Bad source register name", token); -   } - -   /* init swizzle fields */ -   srcReg->Swizzle = SWIZZLE_NOOP; - -   /* Look for optional swizzle suffix */ -   if (!Peek_Token(parseState, token)) -      RETURN_ERROR; -   if (token[0] == '.') { -      (void) Parse_String(parseState, ".");  /* consume . */ - -      if (!Parse_Token(parseState, token)) -         RETURN_ERROR; - -      if (token[1] == 0) { -         /* single letter swizzle */ -         if (token[0] == 'x') -            srcReg->Swizzle = SWIZZLE_XXXX; -         else if (token[0] == 'y') -            srcReg->Swizzle = SWIZZLE_YYYY; -         else if (token[0] == 'z') -            srcReg->Swizzle = SWIZZLE_ZZZZ; -         else if (token[0] == 'w') -            srcReg->Swizzle = SWIZZLE_WWWW; -         else -            RETURN_ERROR1("Expected x, y, z, or w"); -      } -      else { -         /* 2, 3 or 4-component swizzle */ -         GLint k; - -         srcReg->Swizzle = 0; - -         for (k = 0; token[k] && k < 5; k++) { -            if (token[k] == 'x') -               srcReg->Swizzle |= 0 << (k*3); -            else if (token[k] == 'y') -               srcReg->Swizzle |= 1 << (k*3); -            else if (token[k] == 'z') -               srcReg->Swizzle |= 2 << (k*3); -            else if (token[k] == 'w') -               srcReg->Swizzle |= 3 << (k*3); -            else -               RETURN_ERROR; -         } -         if (k >= 5) -            RETURN_ERROR; -      } -   } - -   return GL_TRUE; -} - - -static GLboolean -Parse_ScalarSrcReg(struct parse_state *parseState, struct prog_src_register *srcReg) -{ -   GLubyte token[100]; -   GLint idx; - -   srcReg->RelAddr = GL_FALSE; - -   /* check for '-' */ -   if (!Peek_Token(parseState, token)) -      RETURN_ERROR; -   if (token[0] == '-') { -      srcReg->Negate = NEGATE_XYZW; -      (void) Parse_String(parseState, "-"); /* consume '-' */ -      if (!Peek_Token(parseState, token)) -         RETURN_ERROR; -   } -   else { -      srcReg->Negate = NEGATE_NONE; -   } - -   /* Src reg can be R<n>, c[n], c[n +/- offset], or a named vertex attrib */ -   if (token[0] == 'R') { -      srcReg->File = PROGRAM_TEMPORARY; -      if (!Parse_TempReg(parseState, &idx)) -         RETURN_ERROR; -      srcReg->Index = idx; -   } -   else if (token[0] == 'c') { -      if (!Parse_ParamReg(parseState, srcReg)) -         RETURN_ERROR; -   } -   else if (token[0] == 'v') { -      srcReg->File = PROGRAM_INPUT; -      if (!Parse_AttribReg(parseState, &idx)) -         RETURN_ERROR; -      srcReg->Index = idx; -   } -   else { -      RETURN_ERROR2("Bad source register name", token); -   } - -   /* Look for .[xyzw] suffix */ -   if (!Parse_String(parseState, ".")) -      RETURN_ERROR; - -   if (!Parse_Token(parseState, token)) -      RETURN_ERROR; - -   if (token[0] == 'x' && token[1] == 0) { -      srcReg->Swizzle = 0; -   } -   else if (token[0] == 'y' && token[1] == 0) { -      srcReg->Swizzle = 1; -   } -   else if (token[0] == 'z' && token[1] == 0) { -      srcReg->Swizzle = 2; -   } -   else if (token[0] == 'w' && token[1] == 0) { -      srcReg->Swizzle = 3; -   } -   else { -      RETURN_ERROR1("Bad scalar source suffix"); -   } - -   return GL_TRUE; -} - - -static GLint -Parse_UnaryOpInstruction(struct parse_state *parseState, -                         struct prog_instruction *inst, -                         enum prog_opcode opcode) -{ -   if (opcode == OPCODE_ABS && !parseState->isVersion1_1) -      RETURN_ERROR1("ABS illegal for vertex program 1.0"); - -   inst->Opcode = opcode; - -   /* dest reg */ -   if (!Parse_MaskedDstReg(parseState, &inst->DstReg)) -      RETURN_ERROR; - -   /* comma */ -   if (!Parse_String(parseState, ",")) -      RETURN_ERROR; - -   /* src arg */ -   if (!Parse_SwizzleSrcReg(parseState, &inst->SrcReg[0])) -      RETURN_ERROR; - -   /* semicolon */ -   if (!Parse_String(parseState, ";")) -      RETURN_ERROR; - -   return GL_TRUE; -} - - -static GLboolean -Parse_BiOpInstruction(struct parse_state *parseState, -                      struct prog_instruction *inst, -                      enum prog_opcode opcode) -{ -   if (opcode == OPCODE_DPH && !parseState->isVersion1_1) -      RETURN_ERROR1("DPH illegal for vertex program 1.0"); -   if (opcode == OPCODE_SUB && !parseState->isVersion1_1) -      RETURN_ERROR1("SUB illegal for vertex program 1.0"); - -   inst->Opcode = opcode; - -   /* dest reg */ -   if (!Parse_MaskedDstReg(parseState, &inst->DstReg)) -      RETURN_ERROR; - -   /* comma */ -   if (!Parse_String(parseState, ",")) -      RETURN_ERROR; - -   /* first src arg */ -   if (!Parse_SwizzleSrcReg(parseState, &inst->SrcReg[0])) -      RETURN_ERROR; - -   /* comma */ -   if (!Parse_String(parseState, ",")) -      RETURN_ERROR; - -   /* second src arg */ -   if (!Parse_SwizzleSrcReg(parseState, &inst->SrcReg[1])) -      RETURN_ERROR; - -   /* semicolon */ -   if (!Parse_String(parseState, ";")) -      RETURN_ERROR; - -   /* make sure we don't reference more than one program parameter register */ -   if (inst->SrcReg[0].File == PROGRAM_ENV_PARAM && -       inst->SrcReg[1].File == PROGRAM_ENV_PARAM && -       inst->SrcReg[0].Index != inst->SrcReg[1].Index) -      RETURN_ERROR1("Can't reference two program parameter registers"); - -   /* make sure we don't reference more than one vertex attribute register */ -   if (inst->SrcReg[0].File == PROGRAM_INPUT && -       inst->SrcReg[1].File == PROGRAM_INPUT && -       inst->SrcReg[0].Index != inst->SrcReg[1].Index) -      RETURN_ERROR1("Can't reference two vertex attribute registers"); - -   return GL_TRUE; -} - - -static GLboolean -Parse_TriOpInstruction(struct parse_state *parseState, -                       struct prog_instruction *inst, -                       enum prog_opcode opcode) -{ -   inst->Opcode = opcode; - -   /* dest reg */ -   if (!Parse_MaskedDstReg(parseState, &inst->DstReg)) -      RETURN_ERROR; - -   /* comma */ -   if (!Parse_String(parseState, ",")) -      RETURN_ERROR; - -   /* first src arg */ -   if (!Parse_SwizzleSrcReg(parseState, &inst->SrcReg[0])) -      RETURN_ERROR; - -   /* comma */ -   if (!Parse_String(parseState, ",")) -      RETURN_ERROR; - -   /* second src arg */ -   if (!Parse_SwizzleSrcReg(parseState, &inst->SrcReg[1])) -      RETURN_ERROR; - -   /* comma */ -   if (!Parse_String(parseState, ",")) -      RETURN_ERROR; - -   /* third src arg */ -   if (!Parse_SwizzleSrcReg(parseState, &inst->SrcReg[2])) -      RETURN_ERROR; - -   /* semicolon */ -   if (!Parse_String(parseState, ";")) -      RETURN_ERROR; - -   /* make sure we don't reference more than one program parameter register */ -   if ((inst->SrcReg[0].File == PROGRAM_ENV_PARAM && -        inst->SrcReg[1].File == PROGRAM_ENV_PARAM && -        inst->SrcReg[0].Index != inst->SrcReg[1].Index) || -       (inst->SrcReg[0].File == PROGRAM_ENV_PARAM && -        inst->SrcReg[2].File == PROGRAM_ENV_PARAM && -        inst->SrcReg[0].Index != inst->SrcReg[2].Index) || -       (inst->SrcReg[1].File == PROGRAM_ENV_PARAM && -        inst->SrcReg[2].File == PROGRAM_ENV_PARAM && -        inst->SrcReg[1].Index != inst->SrcReg[2].Index)) -      RETURN_ERROR1("Can only reference one program register"); - -   /* make sure we don't reference more than one vertex attribute register */ -   if ((inst->SrcReg[0].File == PROGRAM_INPUT && -        inst->SrcReg[1].File == PROGRAM_INPUT && -        inst->SrcReg[0].Index != inst->SrcReg[1].Index) || -       (inst->SrcReg[0].File == PROGRAM_INPUT && -        inst->SrcReg[2].File == PROGRAM_INPUT && -        inst->SrcReg[0].Index != inst->SrcReg[2].Index) || -       (inst->SrcReg[1].File == PROGRAM_INPUT && -        inst->SrcReg[2].File == PROGRAM_INPUT && -        inst->SrcReg[1].Index != inst->SrcReg[2].Index)) -      RETURN_ERROR1("Can only reference one input register"); - -   return GL_TRUE; -} - - -static GLboolean -Parse_ScalarInstruction(struct parse_state *parseState, -                        struct prog_instruction *inst, -                        enum prog_opcode opcode) -{ -   if (opcode == OPCODE_RCC && !parseState->isVersion1_1) -      RETURN_ERROR1("RCC illegal for vertex program 1.0"); - -   inst->Opcode = opcode; - -   /* dest reg */ -   if (!Parse_MaskedDstReg(parseState, &inst->DstReg)) -      RETURN_ERROR; - -   /* comma */ -   if (!Parse_String(parseState, ",")) -      RETURN_ERROR; - -   /* first src arg */ -   if (!Parse_ScalarSrcReg(parseState, &inst->SrcReg[0])) -      RETURN_ERROR; - -   /* semicolon */ -   if (!Parse_String(parseState, ";")) -      RETURN_ERROR; - -   return GL_TRUE; -} - - -static GLboolean -Parse_AddressInstruction(struct parse_state *parseState, struct prog_instruction *inst) -{ -   inst->Opcode = OPCODE_ARL; - -   /* Make ARB_vp backends happy */ -   inst->DstReg.File = PROGRAM_ADDRESS; -   inst->DstReg.WriteMask = WRITEMASK_X; -   inst->DstReg.Index = 0; - -   /* dest A0 reg */ -   if (!Parse_AddrReg(parseState)) -      RETURN_ERROR; - -   /* comma */ -   if (!Parse_String(parseState, ",")) -      RETURN_ERROR; - -   /* parse src reg */ -   if (!Parse_ScalarSrcReg(parseState, &inst->SrcReg[0])) -      RETURN_ERROR; - -   /* semicolon */ -   if (!Parse_String(parseState, ";")) -      RETURN_ERROR; - -   return GL_TRUE; -} - - -static GLboolean -Parse_EndInstruction(struct parse_state *parseState, struct prog_instruction *inst) -{ -   GLubyte token[100]; - -   inst->Opcode = OPCODE_END; - -   /* this should fail! */ -   if (Parse_Token(parseState, token)) -      RETURN_ERROR2("Unexpected token after END:", token); -   else -      return GL_TRUE; -} - - -/** - * The PRINT instruction is Mesa-specific and is meant as a debugging aid for - * the vertex program developer. - * The NV_vertex_program extension grammar is modified as follows: - * - *  <instruction>        ::= <ARL-instruction> - *                         | ... - *                         | <PRINT-instruction> - * - *  <PRINT-instruction>  ::= "PRINT" <string literal> - *                         | "PRINT" <string literal> "," <srcReg> - *                         | "PRINT" <string literal> "," <dstReg> - */ -static GLboolean -Parse_PrintInstruction(struct parse_state *parseState, struct prog_instruction *inst) -{ -   const GLubyte *str; -   GLubyte *msg; -   GLuint len; -   GLubyte token[100]; -   struct prog_src_register *srcReg = &inst->SrcReg[0]; -   GLint idx; - -   inst->Opcode = OPCODE_PRINT; - -   /* The first argument is a literal string 'just like this' */ -   if (!Parse_String(parseState, "'")) -      RETURN_ERROR; - -   str = parseState->pos; -   for (len = 0; str[len] != '\''; len++) /* find closing quote */ -      ; -   parseState->pos += len + 1; -   msg = malloc(len + 1); - -   memcpy(msg, str, len); -   msg[len] = 0; -   inst->Data = msg; - -   /* comma */ -   if (Parse_String(parseState, ",")) { - -      /* The second argument is a register name */ -      if (!Peek_Token(parseState, token)) -         RETURN_ERROR; - -      srcReg->RelAddr = GL_FALSE; -      srcReg->Negate = NEGATE_NONE; -      srcReg->Swizzle = SWIZZLE_NOOP; - -      /* Register can be R<n>, c[n], c[n +/- offset], a named vertex attrib, -       * or an o[n] output register. -       */ -      if (token[0] == 'R') { -         srcReg->File = PROGRAM_TEMPORARY; -         if (!Parse_TempReg(parseState, &idx)) -            RETURN_ERROR; -	 srcReg->Index = idx; -      } -      else if (token[0] == 'c') { -         srcReg->File = PROGRAM_ENV_PARAM; -         if (!Parse_ParamReg(parseState, srcReg)) -            RETURN_ERROR; -      } -      else if (token[0] == 'v') { -         srcReg->File = PROGRAM_INPUT; -         if (!Parse_AttribReg(parseState, &idx)) -            RETURN_ERROR; -	 srcReg->Index = idx; -      } -      else if (token[0] == 'o') { -         srcReg->File = PROGRAM_OUTPUT; -         if (!Parse_OutputReg(parseState, &idx)) -            RETURN_ERROR; -	 srcReg->Index = idx; -      } -      else { -         RETURN_ERROR2("Bad source register name", token); -      } -   } -   else { -      srcReg->File = PROGRAM_UNDEFINED; -   } - -   /* semicolon */ -   if (!Parse_String(parseState, ";")) -      RETURN_ERROR; - -   return GL_TRUE; -} - - -static GLboolean -Parse_OptionSequence(struct parse_state *parseState, -                     struct prog_instruction program[]) -{ -   (void) program; -   while (1) { -      if (!Parse_String(parseState, "OPTION")) -         return GL_TRUE;  /* ok, not an OPTION statement */ -      if (Parse_String(parseState, "NV_position_invariant")) { -         parseState->isPositionInvariant = GL_TRUE; -      } -      else { -         RETURN_ERROR1("unexpected OPTION statement"); -      } -      if (!Parse_String(parseState, ";")) -         return GL_FALSE; -   } -} - - -static GLboolean -Parse_InstructionSequence(struct parse_state *parseState, -                          struct prog_instruction program[]) -{ -   while (1) { -      struct prog_instruction *inst = program + parseState->numInst; - -      /* Initialize the instruction */ -      _mesa_init_instructions(inst, 1); - -      if (Parse_String(parseState, "MOV")) { -         if (!Parse_UnaryOpInstruction(parseState, inst, OPCODE_MOV)) -            RETURN_ERROR; -      } -      else if (Parse_String(parseState, "LIT")) { -         if (!Parse_UnaryOpInstruction(parseState, inst, OPCODE_LIT)) -            RETURN_ERROR; -      } -      else if (Parse_String(parseState, "ABS")) { -         if (!Parse_UnaryOpInstruction(parseState, inst, OPCODE_ABS)) -            RETURN_ERROR; -      } -      else if (Parse_String(parseState, "MUL")) { -         if (!Parse_BiOpInstruction(parseState, inst, OPCODE_MUL)) -            RETURN_ERROR; -      } -      else if (Parse_String(parseState, "ADD")) { -         if (!Parse_BiOpInstruction(parseState, inst, OPCODE_ADD)) -            RETURN_ERROR; -      } -      else if (Parse_String(parseState, "DP3")) { -         if (!Parse_BiOpInstruction(parseState, inst, OPCODE_DP3)) -            RETURN_ERROR; -      } -      else if (Parse_String(parseState, "DP4")) { -         if (!Parse_BiOpInstruction(parseState, inst, OPCODE_DP4)) -            RETURN_ERROR; -      } -      else if (Parse_String(parseState, "DST")) { -         if (!Parse_BiOpInstruction(parseState, inst, OPCODE_DST)) -            RETURN_ERROR; -      } -      else if (Parse_String(parseState, "MIN")) { -         if (!Parse_BiOpInstruction(parseState, inst, OPCODE_MIN)) -            RETURN_ERROR; -      } -      else if (Parse_String(parseState, "MAX")) { -         if (!Parse_BiOpInstruction(parseState, inst, OPCODE_MAX)) -            RETURN_ERROR; -      } -      else if (Parse_String(parseState, "SLT")) { -         if (!Parse_BiOpInstruction(parseState, inst, OPCODE_SLT)) -            RETURN_ERROR; -      } -      else if (Parse_String(parseState, "SGE")) { -         if (!Parse_BiOpInstruction(parseState, inst, OPCODE_SGE)) -            RETURN_ERROR; -      } -      else if (Parse_String(parseState, "DPH")) { -         if (!Parse_BiOpInstruction(parseState, inst, OPCODE_DPH)) -            RETURN_ERROR; -      } -      else if (Parse_String(parseState, "SUB")) { -         if (!Parse_BiOpInstruction(parseState, inst, OPCODE_SUB)) -            RETURN_ERROR; -      } -      else if (Parse_String(parseState, "MAD")) { -         if (!Parse_TriOpInstruction(parseState, inst, OPCODE_MAD)) -            RETURN_ERROR; -      } -      else if (Parse_String(parseState, "RCP")) { -         if (!Parse_ScalarInstruction(parseState, inst, OPCODE_RCP)) -            RETURN_ERROR; -      } -      else if (Parse_String(parseState, "RSQ")) { -         if (!Parse_ScalarInstruction(parseState, inst, OPCODE_RSQ)) -            RETURN_ERROR; -      } -      else if (Parse_String(parseState, "EXP")) { -         if (!Parse_ScalarInstruction(parseState, inst, OPCODE_EXP)) -            RETURN_ERROR; -      } -      else if (Parse_String(parseState, "LOG")) { -         if (!Parse_ScalarInstruction(parseState, inst, OPCODE_LOG)) -            RETURN_ERROR; -      } -      else if (Parse_String(parseState, "RCC")) { -         if (!Parse_ScalarInstruction(parseState, inst, OPCODE_RCC)) -            RETURN_ERROR; -      } -      else if (Parse_String(parseState, "ARL")) { -         if (!Parse_AddressInstruction(parseState, inst)) -            RETURN_ERROR; -      } -      else if (Parse_String(parseState, "PRINT")) { -         if (!Parse_PrintInstruction(parseState, inst)) -            RETURN_ERROR; -      } -      else if (Parse_String(parseState, "END")) { -         if (!Parse_EndInstruction(parseState, inst)) -            RETURN_ERROR; -         else { -            parseState->numInst++; -            return GL_TRUE;  /* all done */ -         } -      } -      else { -         /* bad instruction name */ -         RETURN_ERROR1("Unexpected token"); -      } - -      /* examine input/output registers */ -      if (inst->DstReg.File == PROGRAM_OUTPUT) -         parseState->outputsWritten |= (1 << inst->DstReg.Index); -      else if (inst->DstReg.File == PROGRAM_ENV_PARAM) -         parseState->anyProgRegsWritten = GL_TRUE; - -      if (inst->SrcReg[0].File == PROGRAM_INPUT) -         parseState->inputsRead |= (1 << inst->SrcReg[0].Index); -      if (inst->SrcReg[1].File == PROGRAM_INPUT) -         parseState->inputsRead |= (1 << inst->SrcReg[1].Index); -      if (inst->SrcReg[2].File == PROGRAM_INPUT) -         parseState->inputsRead |= (1 << inst->SrcReg[2].Index); - -      parseState->numInst++; - -      if (parseState->numInst >= MAX_NV_VERTEX_PROGRAM_INSTRUCTIONS) -         RETURN_ERROR1("Program too long"); -   } - -   RETURN_ERROR; -} - - -static GLboolean -Parse_Program(struct parse_state *parseState, -              struct prog_instruction instBuffer[]) -{ -   if (parseState->isVersion1_1) { -      if (!Parse_OptionSequence(parseState, instBuffer)) { -         return GL_FALSE; -      } -   } -   return Parse_InstructionSequence(parseState, instBuffer); -} - - -/** - * Parse/compile the 'str' returning the compiled 'program'. - * ctx->Program.ErrorPos will be -1 if successful.  Otherwise, ErrorPos - * indicates the position of the error in 'str'. - */ -void -_mesa_parse_nv_vertex_program(struct gl_context *ctx, GLenum dstTarget, -                              const GLubyte *str, GLsizei len, -                              struct gl_vertex_program *program) -{ -   struct parse_state parseState; -   struct prog_instruction instBuffer[MAX_NV_VERTEX_PROGRAM_INSTRUCTIONS]; -   struct prog_instruction *newInst; -   GLenum target; -   GLubyte *programString; - -   /* Make a null-terminated copy of the program string */ -   programString = malloc(len + 1); -   if (!programString) { -      _mesa_error(ctx, GL_OUT_OF_MEMORY, "glLoadProgramNV"); -      return; -   } -   memcpy(programString, str, len); -   programString[len] = 0; - -   /* Get ready to parse */ -   parseState.ctx = ctx; -   parseState.start = programString; -   parseState.isPositionInvariant = GL_FALSE; -   parseState.isVersion1_1 = GL_FALSE; -   parseState.numInst = 0; -   parseState.inputsRead = 0; -   parseState.outputsWritten = 0; -   parseState.anyProgRegsWritten = GL_FALSE; -   parseState.indirectRegisterFiles = 0x0; - -   /* Reset error state */ -   _mesa_set_program_error(ctx, -1, NULL); - -   /* check the program header */ -   if (strncmp((const char *) programString, "!!VP1.0", 7) == 0) { -      target = GL_VERTEX_PROGRAM_NV; -      parseState.pos = programString + 7; -      parseState.isStateProgram = GL_FALSE; -   } -   else if (strncmp((const char *) programString, "!!VP1.1", 7) == 0) { -      target = GL_VERTEX_PROGRAM_NV; -      parseState.pos = programString + 7; -      parseState.isStateProgram = GL_FALSE; -      parseState.isVersion1_1 = GL_TRUE; -   } -   else if (strncmp((const char *) programString, "!!VSP1.0", 8) == 0) { -      target = GL_VERTEX_STATE_PROGRAM_NV; -      parseState.pos = programString + 8; -      parseState.isStateProgram = GL_TRUE; -   } -   else { -      /* invalid header */ -      ctx->Program.ErrorPos = 0; -      _mesa_error(ctx, GL_INVALID_OPERATION, "glLoadProgramNV(bad header)"); -      return; -   } - -   /* make sure target and header match */ -   if (target != dstTarget) { -      _mesa_error(ctx, GL_INVALID_OPERATION, -                  "glLoadProgramNV(target mismatch)"); -      return; -   } - - -   if (Parse_Program(&parseState, instBuffer)) { -      gl_state_index state_tokens[STATE_LENGTH] = {0, 0, 0, 0, 0}; -      int i; - -      /* successful parse! */ - -      if (parseState.isStateProgram) { -         if (!parseState.anyProgRegsWritten) { -            _mesa_error(ctx, GL_INVALID_OPERATION, -                        "glLoadProgramNV(c[#] not written)"); -            return; -         } -      } -      else { -         if (!parseState.isPositionInvariant && -             !(parseState.outputsWritten & (1 << VERT_RESULT_HPOS))) { -            /* bit 1 = HPOS register */ -            _mesa_error(ctx, GL_INVALID_OPERATION, -                        "glLoadProgramNV(HPOS not written)"); -            return; -         } -      } - -      /* copy the compiled instructions */ -      assert(parseState.numInst <= MAX_NV_VERTEX_PROGRAM_INSTRUCTIONS); -      newInst = _mesa_alloc_instructions(parseState.numInst); -      if (!newInst) { -         _mesa_error(ctx, GL_OUT_OF_MEMORY, "glLoadProgramNV"); -         free(programString); -         return;  /* out of memory */ -      } -      _mesa_copy_instructions(newInst, instBuffer, parseState.numInst); - -      /* install the program */ -      program->Base.Target = target; -      free(program->Base.String); -      program->Base.String = programString; -      program->Base.Format = GL_PROGRAM_FORMAT_ASCII_ARB; -      free(program->Base.Instructions); -      program->Base.Instructions = newInst; -      program->Base.InputsRead = parseState.inputsRead; -      if (parseState.isPositionInvariant) -         program->Base.InputsRead |= VERT_BIT_POS; -      program->Base.NumInstructions = parseState.numInst; -      program->Base.OutputsWritten = parseState.outputsWritten; -      program->IsPositionInvariant = parseState.isPositionInvariant; -      program->IsNVProgram = GL_TRUE; - -#ifdef DEBUG_foo -      printf("--- glLoadProgramNV result ---\n"); -      _mesa_fprint_program_opt(stdout, &program->Base, PROG_PRINT_NV, 0); -      printf("------------------------------\n"); -#endif - -      if (program->Base.Parameters) -	 _mesa_free_parameter_list(program->Base.Parameters); - -      program->Base.Parameters = _mesa_new_parameter_list (); -      program->Base.NumParameters = 0; - -      program->Base.IndirectRegisterFiles = parseState.indirectRegisterFiles; - -      state_tokens[0] = STATE_VERTEX_PROGRAM; -      state_tokens[1] = STATE_ENV; -      /* Add refs to all of the potential params, in order.  If we want to not -       * upload everything, _mesa_layout_parameters is the answer. -       */ -      for (i = 0; i < MAX_NV_VERTEX_PROGRAM_PARAMS; i++) { -	 GLint index; -	 state_tokens[2] = i; -	 index = _mesa_add_state_reference(program->Base.Parameters, -					   state_tokens); -	 assert(index == i); -	 (void)index; -      } -      program->Base.NumParameters = program->Base.Parameters->NumParameters; - -      _mesa_setup_nv_temporary_count(&program->Base); -      _mesa_emit_nv_temp_initialization(ctx, &program->Base); -   } -   else { -      /* Error! */ -      _mesa_error(ctx, GL_INVALID_OPERATION, "glLoadProgramNV"); -      /* NOTE: _mesa_set_program_error would have been called already */ -      /* GL_NV_vertex_program isn't supposed to set the error string -       * so we reset it here. -       */ -      _mesa_set_program_error(ctx, ctx->Program.ErrorPos, NULL); -   } -} - - -const char * -_mesa_nv_vertex_input_register_name(GLuint i) -{ -   ASSERT(i < MAX_NV_VERTEX_PROGRAM_INPUTS); -   return InputRegisters[i]; -} - - -const char * -_mesa_nv_vertex_output_register_name(GLuint i) -{ -   ASSERT(i < MAX_NV_VERTEX_PROGRAM_OUTPUTS); -   return OutputRegisters[i]; -} - diff --git a/mesalib/src/mesa/program/nvvertparse.h b/mesalib/src/mesa/program/nvvertparse.h deleted file mode 100644 index 7318e1494..000000000 --- a/mesalib/src/mesa/program/nvvertparse.h +++ /dev/null @@ -1,49 +0,0 @@ -/* - * Mesa 3-D graphics library - * Version:  5.1 - * - * Copyright (C) 1999-2003  Brian Paul   All Rights Reserved. - * - * Permission is hereby granted, free of charge, to any person obtaining a - * copy of this software and associated documentation files (the "Software"), - * to deal in the Software without restriction, including without limitation - * the rights to use, copy, modify, merge, publish, distribute, sublicense, - * and/or sell copies of the Software, and to permit persons to whom the - * Software is furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included - * in all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS - * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL - * BRIAN PAUL BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN - * AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN - * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - * - * Authors: - *    Brian Paul - */ - - -#ifndef NVVERTPARSE_H -#define NVVERTPARSE_H - -#include "main/glheader.h" - -struct gl_context; -struct gl_vertex_program; - -extern void -_mesa_parse_nv_vertex_program(struct gl_context *ctx, GLenum target, -                              const GLubyte *str, GLsizei len, -                              struct gl_vertex_program *program); - - -extern const char * -_mesa_nv_vertex_input_register_name(GLuint i); - -extern const char * -_mesa_nv_vertex_output_register_name(GLuint i); - -#endif diff --git a/mesalib/src/mesa/program/prog_execute.c b/mesalib/src/mesa/program/prog_execute.c index dd1706e14..9ee2f2014 100644 --- a/mesalib/src/mesa/program/prog_execute.c +++ b/mesalib/src/mesa/program/prog_execute.c @@ -79,23 +79,6 @@  static const GLfloat ZeroVec[4] = { 0.0F, 0.0F, 0.0F, 0.0F }; - -/** - * Return TRUE for +0 and other positive values, FALSE otherwise. - * Used for RCC opcode. - */ -static inline GLboolean -positive(float x) -{ -   fi_type fi; -   fi.f = x; -   if (fi.i & 0x80000000) -      return GL_FALSE; -   return GL_TRUE; -} - - -  /**   * Return a pointer to the 4-element float vector specified by the given   * source register. @@ -153,8 +136,6 @@ get_src_register_pointer(const struct prog_src_register *source,     case PROGRAM_CONSTANT:        /* Fallthrough */     case PROGRAM_UNIFORM: -      /* Fallthrough */ -   case PROGRAM_NAMED_PARAM:        if (reg >= (GLint) prog->Parameters->NumParameters)           return ZeroVec;        return (GLfloat *) prog->Parameters->ParameterValues[reg]; @@ -202,9 +183,6 @@ get_dst_register_pointer(const struct prog_dst_register *dest,           return dummyReg;        return machine->Outputs[reg]; -   case PROGRAM_WRITE_ONLY: -      return dummyReg; -     default:        _mesa_problem(NULL,           "Invalid dest register file %d in get_dst_register_pointer()", @@ -728,13 +706,6 @@ _mesa_execute_program(struct gl_context * ctx,           break;        case OPCODE_ENDSUB:      /* end subroutine */           break; -      case OPCODE_BRA:         /* branch (conditional) */ -         if (eval_condition(machine, inst)) { -            /* take branch */ -            /* Subtract 1 here since we'll do pc++ below */ -            pc = inst->BranchTarget - 1; -         } -         break;        case OPCODE_BRK:         /* break out of loop (conditional) */           ASSERT(program->Instructions[inst->BranchTarget].Opcode                  == OPCODE_ENDLOOP); @@ -1367,43 +1338,6 @@ _mesa_execute_program(struct gl_context * ctx,              store_vector4(inst, machine, result);           }           break; -      case OPCODE_RCC:  /* clamped riciprocal */ -         { -            const float largest = 1.884467e+19, smallest = 5.42101e-20; -            GLfloat a[4], r, result[4]; -            fetch_vector1(&inst->SrcReg[0], machine, a); -            if (DEBUG_PROG) { -               if (a[0] == 0) -                  printf("RCC(0)\n"); -               else if (IS_INF_OR_NAN(a[0])) -                  printf("RCC(inf)\n"); -            } -            if (a[0] == 1.0F) { -               r = 1.0F; -            } -            else { -               r = 1.0F / a[0]; -            } -            if (positive(r)) { -               if (r > largest) { -                  r = largest; -               } -               else if (r < smallest) { -                  r = smallest; -               } -            } -            else { -               if (r < -largest) { -                  r = -largest; -               } -               else if (r > -smallest) { -                  r = -smallest; -               } -            } -            result[0] = result[1] = result[2] = result[3] = r; -            store_vector4(inst, machine, result); -         } -         break;        case OPCODE_RCP:           { diff --git a/mesalib/src/mesa/program/prog_instruction.c b/mesalib/src/mesa/program/prog_instruction.c index d69d7b2d4..0bd45b09b 100644 --- a/mesalib/src/mesa/program/prog_instruction.c +++ b/mesalib/src/mesa/program/prog_instruction.c @@ -154,13 +154,9 @@ static const struct instruction_info InstInfo[MAX_OPCODE] = {     { OPCODE_ABS,    "ABS",     1, 1 },     { OPCODE_ADD,    "ADD",     2, 1 },     { OPCODE_AND,    "AND",     2, 1 }, -   { OPCODE_ARA,    "ARA",     1, 1 },     { OPCODE_ARL,    "ARL",     1, 1 }, -   { OPCODE_ARL_NV, "ARL_NV",  1, 1 }, -   { OPCODE_ARR,    "ARL",     1, 1 },     { OPCODE_BGNLOOP,"BGNLOOP", 0, 0 },     { OPCODE_BGNSUB, "BGNSUB",  0, 0 }, -   { OPCODE_BRA,    "BRA",     0, 0 },     { OPCODE_BRK,    "BRK",     0, 0 },     { OPCODE_CAL,    "CAL",     0, 0 },     { OPCODE_CMP,    "CMP",     3, 1 }, @@ -210,10 +206,7 @@ static const struct instruction_info InstInfo[MAX_OPCODE] = {     { OPCODE_PK4B,   "PK4B",    1, 1 },     { OPCODE_PK4UB,  "PK4UB",   1, 1 },     { OPCODE_POW,    "POW",     2, 1 }, -   { OPCODE_POPA,   "POPA",    0, 0 },     { OPCODE_PRINT,  "PRINT",   1, 0 }, -   { OPCODE_PUSHA,  "PUSHA",   0, 0 }, -   { OPCODE_RCC,    "RCC",     1, 1 },     { OPCODE_RCP,    "RCP",     1, 1 },     { OPCODE_RET,    "RET",     0, 0 },     { OPCODE_RFL,    "RFL",     1, 1 }, diff --git a/mesalib/src/mesa/program/prog_instruction.h b/mesalib/src/mesa/program/prog_instruction.h index 656556dd4..8bb0c6541 100644 --- a/mesalib/src/mesa/program/prog_instruction.h +++ b/mesalib/src/mesa/program/prog_instruction.h @@ -148,13 +148,9 @@ typedef enum prog_opcode {     OPCODE_ABS,       /*   X        X       1.1               X   */     OPCODE_ADD,       /*   X        X       X       X         X   */     OPCODE_AND,       /*                                          */ -   OPCODE_ARA,       /*                    2                     */     OPCODE_ARL,       /*   X                X                 X   */ -   OPCODE_ARL_NV,    /*                    2                     */ -   OPCODE_ARR,       /*                    2                     */     OPCODE_BGNLOOP,   /*                                     opt  */     OPCODE_BGNSUB,    /*                                     opt  */ -   OPCODE_BRA,       /*                    2                     */     OPCODE_BRK,       /*                    2                opt  */     OPCODE_CAL,       /*                    2       2        opt  */     OPCODE_CMP,       /*            X                         X   */ @@ -204,10 +200,7 @@ typedef enum prog_opcode {     OPCODE_PK4B,      /*                            X             */     OPCODE_PK4UB,     /*                            X             */     OPCODE_POW,       /*   X        X               X         X   */ -   OPCODE_POPA,      /*                    3                     */     OPCODE_PRINT,     /*                    X       X             */ -   OPCODE_PUSHA,     /*                    3                     */ -   OPCODE_RCC,       /*                    1.1                   */     OPCODE_RCP,       /*   X        X       X       X         X   */     OPCODE_RET,       /*                    2       2        opt  */     OPCODE_RFL,       /*                            X             */ @@ -304,8 +297,7 @@ struct prog_dst_register      * \name Conditional destination update control.      *      * \since -    * NV_fragment_program, NV_fragment_program_option, NV_vertex_program2, -    * NV_vertex_program2_option. +    * NV_fragment_program_option, NV_vertex_program2, NV_vertex_program2_option.      */     /*@{*/     /** @@ -320,15 +312,6 @@ struct prog_dst_register      * Condition code swizzle value.      */     GLuint CondSwizzle:12; - -   /** -    * Selects the condition code register to use for conditional destination -    * update masking.  In NV_fragmnet_program or NV_vertex_program2 mode, only -    * condition code register 0 is available.  In NV_vertex_program3 mode, -    * condition code registers 0 and 1 are available. -    */ -   GLuint CondSrc:1; -   /*@}*/  }; @@ -346,8 +329,7 @@ struct prog_instruction      * register.      *      * \since -    * NV_fragment_program, NV_fragment_program_option, NV_vertex_program2, -    * NV_vertex_program2_option. +    * NV_fragment_program_option, NV_vertex_program2, NV_vertex_program2_option.      */     GLuint CondUpdate:1; @@ -360,8 +342,7 @@ struct prog_instruction      * code registers 0 and 1 are available.      *      * \since -    * NV_fragment_program, NV_fragment_program_option, NV_vertex_program2, -    * NV_vertex_program2_option. +    * NV_fragment_program_option, NV_vertex_program2, NV_vertex_program2_option.      */     GLuint CondDst:1; @@ -372,7 +353,7 @@ struct prog_instruction      * Value is one of the SATURATE_* tokens.      *      * \since -    * NV_fragment_program, NV_fragment_program_option, NV_vertex_program3. +    * NV_fragment_program_option, NV_vertex_program3.      */     GLuint SaturateMode:2; @@ -380,7 +361,7 @@ struct prog_instruction      * Per-instruction selectable precision: FLOAT32, FLOAT16, FIXED12.      *      * \since -    * NV_fragment_program, NV_fragment_program_option. +    * NV_fragment_program_option.      */     GLuint Precision:3; diff --git a/mesalib/src/mesa/program/prog_optimize.c b/mesalib/src/mesa/program/prog_optimize.c index e89e8d6a4..c1013a5a2 100644 --- a/mesalib/src/mesa/program/prog_optimize.c +++ b/mesalib/src/mesa/program/prog_optimize.c @@ -392,7 +392,6 @@ find_next_use(const struct gl_program *prog,        switch (inst->Opcode) {        case OPCODE_BGNLOOP:        case OPCODE_BGNSUB: -      case OPCODE_BRA:        case OPCODE_CAL:        case OPCODE_CONT:        case OPCODE_IF: @@ -439,7 +438,6 @@ _mesa_is_flow_control_opcode(enum prog_opcode opcode)     switch (opcode) {     case OPCODE_BGNLOOP:     case OPCODE_BGNSUB: -   case OPCODE_BRA:     case OPCODE_CAL:     case OPCODE_CONT:     case OPCODE_IF: @@ -791,7 +789,6 @@ _mesa_remove_extra_moves(struct gl_program *prog)              if (prevInst->DstReg.File == PROGRAM_TEMPORARY &&                  prevInst->DstReg.Index == id &&                  prevInst->DstReg.RelAddr == 0 && -                prevInst->DstReg.CondSrc == 0 &&                   prevInst->DstReg.CondMask == COND_TR) {                 const GLuint dst_mask = prevInst->DstReg.WriteMask; diff --git a/mesalib/src/mesa/program/prog_parameter.c b/mesalib/src/mesa/program/prog_parameter.c index b9f4d9d57..8713d57b5 100644 --- a/mesalib/src/mesa/program/prog_parameter.c +++ b/mesalib/src/mesa/program/prog_parameter.c @@ -109,8 +109,7 @@ _mesa_add_parameter(struct gl_program_parameter_list *paramList,                      gl_register_file type, const char *name,                      GLuint size, GLenum datatype,                      const gl_constant_value *values, -                    const gl_state_index state[STATE_LENGTH], -                    GLbitfield flags) +                    const gl_state_index state[STATE_LENGTH])  {     const GLuint oldNum = paramList->NumParameters;     const GLuint sz4 = (size + 3) / 4; /* no. of new param slots needed */ @@ -155,7 +154,6 @@ _mesa_add_parameter(struct gl_program_parameter_list *paramList,           p->Type = type;           p->Size = size;           p->DataType = datatype; -         p->Flags = flags;           if (values) {              COPY_4V(paramList->ParameterValues[oldNum + i], values);              values += 4; @@ -180,20 +178,6 @@ _mesa_add_parameter(struct gl_program_parameter_list *paramList,  /** - * Add a new named program parameter (Ex: NV_fragment_program DEFINE statement) - * \return index of the new entry in the parameter list - */ -GLint -_mesa_add_named_parameter(struct gl_program_parameter_list *paramList, -                          const char *name, const gl_constant_value values[4]) -{ -   return _mesa_add_parameter(paramList, PROGRAM_NAMED_PARAM, name, -                              4, GL_NONE, values, NULL, 0x0); -                               -} - - -/**   * Add a new named constant to the parameter list.   * This will be used when the program contains something like this:   *    PARAM myVals = { 0, 1, 2, 3 }; @@ -223,7 +207,7 @@ _mesa_add_named_constant(struct gl_program_parameter_list *paramList,     }     /* not found, add new parameter */     return _mesa_add_parameter(paramList, PROGRAM_CONSTANT, name, -                              size, GL_NONE, values, NULL, 0x0); +                              size, GL_NONE, values, NULL);  } @@ -275,7 +259,7 @@ _mesa_add_typed_unnamed_constant(struct gl_program_parameter_list *paramList,     /* add a new parameter to store this constant */     pos = _mesa_add_parameter(paramList, PROGRAM_CONSTANT, NULL, -                             size, datatype, values, NULL, 0x0); +                             size, datatype, values, NULL);     if (pos >= 0 && swizzleOut) {        if (size == 1)           *swizzleOut = SWIZZLE_XXXX; @@ -307,58 +291,6 @@ _mesa_add_unnamed_constant(struct gl_program_parameter_list *paramList,                                             swizzleOut);  } -/** - * Add parameter representing a varying variable. - */ -GLint -_mesa_add_varying(struct gl_program_parameter_list *paramList, -                  const char *name, GLuint size, GLenum datatype, -                  GLbitfield flags) -{ -   GLint i = _mesa_lookup_parameter_index(paramList, -1, name); -   if (i >= 0 && paramList->Parameters[i].Type == PROGRAM_VARYING) { -      /* already in list */ -      return i; -   } -   else { -      /*assert(size == 4);*/ -      i = _mesa_add_parameter(paramList, PROGRAM_VARYING, name, -                              size, datatype, NULL, NULL, flags); -      return i; -   } -} - - -/** - * Add parameter representing a vertex program attribute. - * \param size  size of attribute (in floats), may be -1 if unknown - * \param attrib  the attribute index, or -1 if unknown - */ -GLint -_mesa_add_attribute(struct gl_program_parameter_list *paramList, -                    const char *name, GLint size, GLenum datatype, GLint attrib) -{ -   GLint i = _mesa_lookup_parameter_index(paramList, -1, name); -   if (i >= 0) { -      /* replace */ -      if (attrib < 0) -         attrib = i; -      paramList->Parameters[i].StateIndexes[0] = attrib; -   } -   else { -      /* add */ -      gl_state_index state[STATE_LENGTH]; -      state[0] = (gl_state_index) attrib; -      if (size < 0) -         size = 4; -      i = _mesa_add_parameter(paramList, PROGRAM_INPUT, name, -                              size, datatype, NULL, state, 0x0); -   } -   return i; -} - - -  #if 0 /* not used yet */  /**   * Returns the number of 4-component registers needed to store a piece @@ -410,7 +342,7 @@ _mesa_add_state_reference(struct gl_program_parameter_list *paramList,     name = _mesa_program_state_string(stateTokens);     index = _mesa_add_parameter(paramList, PROGRAM_STATE_VAR, name,                                 size, GL_NONE, -                               NULL, (gl_state_index *) stateTokens, 0x0); +                               NULL, (gl_state_index *) stateTokens);     paramList->StateFlags |= _mesa_program_state_flags(stateTokens);     /* free name string here since we duplicated it in add_parameter() */ @@ -583,10 +515,9 @@ _mesa_clone_parameter_list(const struct gl_program_parameter_list *list)        struct gl_program_parameter *pCopy;        GLuint size = MIN2(p->Size, 4);        GLint j = _mesa_add_parameter(clone, p->Type, p->Name, size, p->DataType, -                                    list->ParameterValues[i], NULL, 0x0); +                                    list->ParameterValues[i], NULL);        ASSERT(j >= 0);        pCopy = clone->Parameters + j; -      pCopy->Flags = p->Flags;        /* copy state indexes */        if (p->Type == PROGRAM_STATE_VAR) {           GLint k; @@ -624,8 +555,7 @@ _mesa_combine_parameter_lists(const struct gl_program_parameter_list *listA,              _mesa_add_parameter(list, param->Type, param->Name, param->Size,                                  param->DataType,                                  listB->ParameterValues[i], -                                param->StateIndexes, -                                param->Flags); +                                param->StateIndexes);           }        }     } @@ -637,21 +567,3 @@ _mesa_combine_parameter_lists(const struct gl_program_parameter_list *listA,     }     return list;  } - - -/** - * Count the number of parameters in the last that match the given type. - */ -GLuint -_mesa_num_parameters_of_type(const struct gl_program_parameter_list *list, -                             gl_register_file type) -{ -   GLuint i, count = 0; -   if (list) { -      for (i = 0; i < list->NumParameters; i++) { -         if (list->Parameters[i].Type == type) -            count++; -      } -   } -   return count; -} diff --git a/mesalib/src/mesa/program/prog_parameter.h b/mesalib/src/mesa/program/prog_parameter.h index 3c6dc8cf9..7b6b4b80e 100644 --- a/mesalib/src/mesa/program/prog_parameter.h +++ b/mesalib/src/mesa/program/prog_parameter.h @@ -41,18 +41,6 @@ extern "C" {  /** - * Program parameter flags - */ -/*@{*/ -#define PROG_PARAM_BIT_CENTROID   0x1  /**< for varying vars (GLSL 1.20) */ -#define PROG_PARAM_BIT_INVARIANT  0x2  /**< for varying vars (GLSL 1.20) */ -#define PROG_PARAM_BIT_FLAT       0x4  /**< for varying vars (GLSL 1.30) */ -#define PROG_PARAM_BIT_LINEAR     0x8  /**< for varying vars (GLSL 1.30) */ -#define PROG_PARAM_BIT_CYL_WRAP  0x10  /**< XXX gallium debug */ -/*@}*/ - - -/**   * Actual data for constant values of parameters.   */  typedef union gl_constant_value @@ -71,7 +59,7 @@ typedef union gl_constant_value  struct gl_program_parameter  {     const char *Name;        /**< Null-terminated string */ -   gl_register_file Type;   /**< PROGRAM_NAMED_PARAM, CONSTANT or STATE_VAR */ +   gl_register_file Type;   /**< PROGRAM_CONSTANT or STATE_VAR */     GLenum DataType;         /**< GL_FLOAT, GL_FLOAT_VEC2, etc */     /**      * Number of components (1..4), or more. @@ -81,7 +69,6 @@ struct gl_program_parameter      */     GLuint Size;     GLboolean Initialized;   /**< debug: Has the ParameterValue[] been set? */ -   GLbitfield Flags;        /**< Bitmask of PROG_PARAM_*_BIT */     /**      * A sequence of STATE_* tokens and integers to identify GL state.      */ @@ -130,12 +117,7 @@ _mesa_add_parameter(struct gl_program_parameter_list *paramList,                      gl_register_file type, const char *name,                      GLuint size, GLenum datatype,                      const gl_constant_value *values, -                    const gl_state_index state[STATE_LENGTH], -                    GLbitfield flags); - -extern GLint -_mesa_add_named_parameter(struct gl_program_parameter_list *paramList, -                          const char *name, const gl_constant_value values[4]); +                    const gl_state_index state[STATE_LENGTH]);  extern GLint  _mesa_add_named_constant(struct gl_program_parameter_list *paramList, @@ -153,15 +135,6 @@ _mesa_add_unnamed_constant(struct gl_program_parameter_list *paramList,                             GLuint *swizzleOut);  extern GLint -_mesa_add_varying(struct gl_program_parameter_list *paramList, -                  const char *name, GLuint size, GLenum datatype, -                  GLbitfield flags); - -extern GLint -_mesa_add_attribute(struct gl_program_parameter_list *paramList, -                    const char *name, GLint size, GLenum datatype, GLint attrib); - -extern GLint  _mesa_add_state_reference(struct gl_program_parameter_list *paramList,                            const gl_state_index stateTokens[STATE_LENGTH]); @@ -178,11 +151,6 @@ _mesa_lookup_parameter_constant(const struct gl_program_parameter_list *list,                                  const gl_constant_value v[], GLuint vSize,                                  GLint *posOut, GLuint *swizzleOut); -extern GLuint -_mesa_num_parameters_of_type(const struct gl_program_parameter_list *list, -                             gl_register_file type); - -  #ifdef __cplusplus  }  #endif diff --git a/mesalib/src/mesa/program/prog_parameter_layout.c b/mesalib/src/mesa/program/prog_parameter_layout.c index e4f2db3b3..e83469059 100644 --- a/mesalib/src/mesa/program/prog_parameter_layout.c +++ b/mesalib/src/mesa/program/prog_parameter_layout.c @@ -173,7 +173,7 @@ _mesa_layout_parameters(struct asm_parser_state *state)  	    continue;  	 } -	 if ((inst->SrcReg[i].Base.File <= PROGRAM_VARYING ) +	 if ((inst->SrcReg[i].Base.File <= PROGRAM_OUTPUT)  	     || (inst->SrcReg[i].Base.File >= PROGRAM_WRITE_ONLY)) {  	    continue;  	 } diff --git a/mesalib/src/mesa/program/prog_print.c b/mesalib/src/mesa/program/prog_print.c index bc5dc5803..a83cce4e3 100644 --- a/mesalib/src/mesa/program/prog_print.c +++ b/mesalib/src/mesa/program/prog_print.c @@ -60,16 +60,10 @@ _mesa_register_file_name(gl_register_file f)        return "INPUT";     case PROGRAM_OUTPUT:        return "OUTPUT"; -   case PROGRAM_NAMED_PARAM: -      return "NAMED";     case PROGRAM_CONSTANT:        return "CONST";     case PROGRAM_UNIFORM:        return "UNIFORM"; -   case PROGRAM_VARYING: -      return "VARYING"; -   case PROGRAM_WRITE_ONLY: -      return "WRITE_ONLY";     case PROGRAM_ADDRESS:        return "ADDR";     case PROGRAM_SAMPLER: @@ -350,9 +344,6 @@ reg_string(gl_register_file f, GLint index, gl_prog_print_mode mode,        case PROGRAM_LOCAL_PARAM:           sprintf(str, "program.local[%s%d]", addr, index);           break; -      case PROGRAM_VARYING: /* extension */ -         sprintf(str, "varying[%s%d]", addr, index); -         break;        case PROGRAM_CONSTANT: /* extension */           sprintf(str, "constant[%s%d]", addr, index);           break; @@ -379,40 +370,6 @@ reg_string(gl_register_file f, GLint index, gl_prog_print_mode mode,        }        break; -   case PROG_PRINT_NV: -      switch (f) { -      case PROGRAM_INPUT: -         if (prog->Target == GL_VERTEX_PROGRAM_ARB) -            sprintf(str, "v[%d]", index); -         else -            sprintf(str, "f[%d]", index); -         break; -      case PROGRAM_OUTPUT: -         sprintf(str, "o[%d]", index); -         break; -      case PROGRAM_TEMPORARY: -         sprintf(str, "R%d", index); -         break; -      case PROGRAM_ENV_PARAM: -         sprintf(str, "c[%d]", index); -         break; -      case PROGRAM_VARYING: /* extension */ -         sprintf(str, "varying[%s%d]", addr, index); -         break; -      case PROGRAM_UNIFORM: /* extension */ -         sprintf(str, "uniform[%s%d]", addr, index); -         break; -      case PROGRAM_CONSTANT: /* extension */ -         sprintf(str, "constant[%s%d]", addr, index); -         break; -      case PROGRAM_STATE_VAR: /* extension */ -         sprintf(str, "state[%s%d]", addr, index); -         break; -      default: -         _mesa_problem(NULL, "bad file in reg_string()"); -      } -      break; -     default:        _mesa_problem(NULL, "bad mode in reg_string()");     } @@ -748,13 +705,6 @@ _mesa_fprint_instruction_opt(FILE *f,        fprint_src_reg(f, &inst->SrcReg[0], mode, prog);        fprint_comment(f, inst);        break; -   case OPCODE_BRA: -      fprintf(f, "BRA %d (%s%s)", -	      inst->BranchTarget, -	      _mesa_condcode_string(inst->DstReg.CondMask), -	      _mesa_swizzle_string(inst->DstReg.CondSwizzle, 0, GL_FALSE)); -      fprint_comment(f, inst); -      break;     case OPCODE_IF:        if (inst->SrcReg[0].File != PROGRAM_UNDEFINED) {           /* Use ordinary register */ @@ -795,15 +745,9 @@ _mesa_fprint_instruction_opt(FILE *f,        break;     case OPCODE_BGNSUB: -      if (mode == PROG_PRINT_NV) { -         fprintf(f, "%s:\n", inst->Comment); /* comment is label */ -         return indent; -      } -      else { -         fprintf(f, "BGNSUB"); -         fprint_comment(f, inst); -         return indent + 3; -      } +      fprintf(f, "BGNSUB"); +      fprint_comment(f, inst); +      return indent + 3;     case OPCODE_ENDSUB:        if (mode == PROG_PRINT_DEBUG) {           fprintf(f, "ENDSUB"); @@ -811,13 +755,8 @@ _mesa_fprint_instruction_opt(FILE *f,        }        break;     case OPCODE_CAL: -      if (mode == PROG_PRINT_NV) { -         fprintf(f, "CAL %s;  # (goto %d)\n", inst->Comment, inst->BranchTarget); -      } -      else { -         fprintf(f, "CAL %u", inst->BranchTarget); -         fprint_comment(f, inst); -      } +      fprintf(f, "CAL %u", inst->BranchTarget); +      fprint_comment(f, inst);        break;     case OPCODE_RET:        fprintf(f, "RET (%s%s)", @@ -900,17 +839,12 @@ _mesa_fprint_program_opt(FILE *f,     case GL_VERTEX_PROGRAM_ARB:        if (mode == PROG_PRINT_ARB)           fprintf(f, "!!ARBvp1.0\n"); -      else if (mode == PROG_PRINT_NV) -         fprintf(f, "!!VP1.0\n");        else           fprintf(f, "# Vertex Program/Shader %u\n", prog->Id);        break;     case GL_FRAGMENT_PROGRAM_ARB: -   case GL_FRAGMENT_PROGRAM_NV:        if (mode == PROG_PRINT_ARB)           fprintf(f, "!!ARBfp1.0\n"); -      else if (mode == PROG_PRINT_NV) -         fprintf(f, "!!FP1.0\n");        else           fprintf(f, "# Fragment Program/Shader %u\n", prog->Id);        break; @@ -1036,14 +970,6 @@ _mesa_fprint_parameter_list(FILE *f,  	      i, param->Size,  	      _mesa_register_file_name(list->Parameters[i].Type),  	      param->Name, v[0], v[1], v[2], v[3]); -      if (param->Flags & PROG_PARAM_BIT_CENTROID) -         fprintf(f, " Centroid"); -      if (param->Flags & PROG_PARAM_BIT_INVARIANT) -         fprintf(f, " Invariant"); -      if (param->Flags & PROG_PARAM_BIT_FLAT) -         fprintf(f, " Flat"); -      if (param->Flags & PROG_PARAM_BIT_LINEAR) -         fprintf(f, " Linear");        fprintf(f, "\n");     }  } diff --git a/mesalib/src/mesa/program/prog_print.h b/mesalib/src/mesa/program/prog_print.h index b95ec2be5..3e400eb46 100644 --- a/mesalib/src/mesa/program/prog_print.h +++ b/mesalib/src/mesa/program/prog_print.h @@ -42,7 +42,6 @@ struct prog_instruction;   */  typedef enum {     PROG_PRINT_ARB, -   PROG_PRINT_NV,     PROG_PRINT_DEBUG  } gl_prog_print_mode; diff --git a/mesalib/src/mesa/program/prog_statevars.c b/mesalib/src/mesa/program/prog_statevars.c index f9c6677b1..5a350798c 100644 --- a/mesalib/src/mesa/program/prog_statevars.c +++ b/mesalib/src/mesa/program/prog_statevars.c @@ -1074,94 +1074,3 @@ _mesa_load_state_parameters(struct gl_context *ctx,        }     }  } - - -/** - * Copy the 16 elements of a matrix into four consecutive program - * registers starting at 'pos'. - */ -static void -load_matrix(GLfloat registers[][4], GLuint pos, const GLfloat mat[16]) -{ -   GLuint i; -   for (i = 0; i < 4; i++) { -      registers[pos + i][0] = mat[0 + i]; -      registers[pos + i][1] = mat[4 + i]; -      registers[pos + i][2] = mat[8 + i]; -      registers[pos + i][3] = mat[12 + i]; -   } -} - - -/** - * As above, but transpose the matrix. - */ -static void -load_transpose_matrix(GLfloat registers[][4], GLuint pos, -                      const GLfloat mat[16]) -{ -   memcpy(registers[pos], mat, 16 * sizeof(GLfloat)); -} - - -/** - * Load current vertex program's parameter registers with tracked - * matrices (if NV program).  This only needs to be done per - * glBegin/glEnd, not per-vertex. - */ -void -_mesa_load_tracked_matrices(struct gl_context *ctx) -{ -   GLuint i; - -   for (i = 0; i < MAX_NV_VERTEX_PROGRAM_PARAMS / 4; i++) { -      /* point 'mat' at source matrix */ -      GLmatrix *mat; -      if (ctx->VertexProgram.TrackMatrix[i] == GL_MODELVIEW) { -         mat = ctx->ModelviewMatrixStack.Top; -      } -      else if (ctx->VertexProgram.TrackMatrix[i] == GL_PROJECTION) { -         mat = ctx->ProjectionMatrixStack.Top; -      } -      else if (ctx->VertexProgram.TrackMatrix[i] == GL_TEXTURE) { -         GLuint unit = MIN2(ctx->Texture.CurrentUnit, -                            Elements(ctx->TextureMatrixStack) - 1); -         mat = ctx->TextureMatrixStack[unit].Top; -      } -      else if (ctx->VertexProgram.TrackMatrix[i]==GL_MODELVIEW_PROJECTION_NV) { -         /* XXX verify the combined matrix is up to date */ -         mat = &ctx->_ModelProjectMatrix; -      } -      else if (ctx->VertexProgram.TrackMatrix[i] >= GL_MATRIX0_NV && -               ctx->VertexProgram.TrackMatrix[i] <= GL_MATRIX7_NV) { -         GLuint n = ctx->VertexProgram.TrackMatrix[i] - GL_MATRIX0_NV; -         ASSERT(n < Elements(ctx->ProgramMatrixStack)); -         mat = ctx->ProgramMatrixStack[n].Top; -      } -      else { -         /* no matrix is tracked, but we leave the register values as-is */ -         assert(ctx->VertexProgram.TrackMatrix[i] == GL_NONE); -         continue; -      } - -      /* load the matrix values into sequential registers */ -      if (ctx->VertexProgram.TrackMatrixTransform[i] == GL_IDENTITY_NV) { -         load_matrix(ctx->VertexProgram.Parameters, i*4, mat->m); -      } -      else if (ctx->VertexProgram.TrackMatrixTransform[i] == GL_INVERSE_NV) { -         _math_matrix_analyse(mat); /* update the inverse */ -         ASSERT(!_math_matrix_is_dirty(mat)); -         load_matrix(ctx->VertexProgram.Parameters, i*4, mat->inv); -      } -      else if (ctx->VertexProgram.TrackMatrixTransform[i] == GL_TRANSPOSE_NV) { -         load_transpose_matrix(ctx->VertexProgram.Parameters, i*4, mat->m); -      } -      else { -         assert(ctx->VertexProgram.TrackMatrixTransform[i] -                == GL_INVERSE_TRANSPOSE_NV); -         _math_matrix_analyse(mat); /* update the inverse */ -         ASSERT(!_math_matrix_is_dirty(mat)); -         load_transpose_matrix(ctx->VertexProgram.Parameters, i*4, mat->inv); -      } -   } -} diff --git a/mesalib/src/mesa/program/prog_statevars.h b/mesalib/src/mesa/program/prog_statevars.h index efd0e030c..af2c89792 100644 --- a/mesalib/src/mesa/program/prog_statevars.h +++ b/mesalib/src/mesa/program/prog_statevars.h @@ -146,9 +146,6 @@ extern char *  _mesa_program_state_string(const gl_state_index state[STATE_LENGTH]); -extern void -_mesa_load_tracked_matrices(struct gl_context *ctx); -  #ifdef __cplusplus  } diff --git a/mesalib/src/mesa/program/program.c b/mesalib/src/mesa/program/program.c index 30f83772f..993803dd5 100644 --- a/mesalib/src/mesa/program/program.c +++ b/mesalib/src/mesa/program/program.c @@ -52,8 +52,6 @@ struct gl_program _mesa_DummyProgram;  void  _mesa_init_program(struct gl_context *ctx)  { -   GLuint i; -     /*      * If this assertion fails, we need to increase the field      * size for register indexes (see INST_INDEX_BITS). @@ -90,10 +88,6 @@ _mesa_init_program(struct gl_context *ctx)     _mesa_reference_vertprog(ctx, &ctx->VertexProgram.Current,                              ctx->Shared->DefaultVertexProgram);     assert(ctx->VertexProgram.Current); -   for (i = 0; i < MAX_NV_VERTEX_PROGRAM_PARAMS / 4; i++) { -      ctx->VertexProgram.TrackMatrix[i] = GL_NONE; -      ctx->VertexProgram.TrackMatrixTransform[i] = GL_IDENTITY_NV; -   }     ctx->VertexProgram.Cache = _mesa_new_program_cache();     ctx->FragmentProgram.Enabled = GL_FALSE; @@ -244,7 +238,6 @@ _mesa_init_program_struct( struct gl_context *ctx, struct gl_program *prog,        memset(prog, 0, sizeof(*prog));        prog->Id = id;        prog->Target = target; -      prog->Resident = GL_TRUE;        prog->RefCount = 1;        prog->Format = GL_PROGRAM_FORMAT_ASCII_ARB; @@ -317,7 +310,6 @@ _mesa_new_program(struct gl_context *ctx, GLenum target, GLuint id)     struct gl_program *prog;     switch (target) {     case GL_VERTEX_PROGRAM_ARB: /* == GL_VERTEX_PROGRAM_NV */ -   case GL_VERTEX_STATE_PROGRAM_NV:        prog = _mesa_init_vertex_program(ctx, CALLOC_STRUCT(gl_vertex_program),                                         target, id );        break; @@ -511,7 +503,6 @@ _mesa_clone_program(struct gl_context *ctx, const struct gl_program *prog)           const struct gl_vertex_program *vp = gl_vertex_program_const(prog);           struct gl_vertex_program *vpc = gl_vertex_program(clone);           vpc->IsPositionInvariant = vp->IsPositionInvariant; -         vpc->IsNVProgram = vp->IsNVProgram;        }        break;     case GL_FRAGMENT_PROGRAM_ARB: @@ -925,9 +916,6 @@ _mesa_valid_register_index(const struct gl_context *ctx,     case PROGRAM_LOCAL_PARAM:        return index >= 0 && index < c->MaxLocalParams; -   case PROGRAM_NAMED_PARAM: -      return index >= 0 && index < c->MaxParameters; -     case PROGRAM_UNIFORM:     case PROGRAM_STATE_VAR:        /* aka constant buffer */ diff --git a/mesalib/src/mesa/program/program_parse.y b/mesalib/src/mesa/program/program_parse.y index 54b17314a..025b54706 100644 --- a/mesalib/src/mesa/program/program_parse.y +++ b/mesalib/src/mesa/program/program_parse.y @@ -468,7 +468,6 @@ KIL_instruction: KIL swizzleSrcReg  	   $$ = asm_instruction_ctor(OPCODE_KIL_NV, NULL, NULL, NULL, NULL);  	   $$->Base.DstReg.CondMask = $2.CondMask;  	   $$->Base.DstReg.CondSwizzle = $2.CondSwizzle; -	   $$->Base.DstReg.CondSrc = $2.CondSrc;  	   state->fragment.UsesKill = 1;  	}  	; @@ -637,7 +636,6 @@ maskedDstReg: dstReg optionalMask optionalCcMask  	   $$.WriteMask = $2.mask;  	   $$.CondMask = $3.CondMask;  	   $$.CondSwizzle = $3.CondSwizzle; -	   $$.CondSrc = $3.CondSrc;  	   if ($$.File == PROGRAM_OUTPUT) {  	      /* Technically speaking, this should check that it is in @@ -1030,7 +1028,6 @@ optionalCcMask: '(' ccTest ')'  	{  	   $$.CondMask = COND_TR;  	   $$.CondSwizzle = SWIZZLE_NOOP; -	   $$.CondSrc = 0;  	}  	; @@ -1067,7 +1064,6 @@ ccMaskRule: IDENTIFIER  	   $$.CondMask = cond;  	   $$.CondSwizzle = SWIZZLE_NOOP; -	   $$.CondSrc = 0;  	}  	; @@ -1090,7 +1086,6 @@ ccMaskRule2: USED_IDENTIFIER  	   $$.CondMask = cond;  	   $$.CondSwizzle = SWIZZLE_NOOP; -	   $$.CondSrc = 0;  	}  	; @@ -2478,7 +2473,7 @@ int add_state_reference(struct gl_program_parameter_list *param_list,     name = _mesa_program_state_string(tokens);     index = _mesa_add_parameter(param_list, PROGRAM_STATE_VAR, name, -                               size, GL_NONE, NULL, tokens, 0x0); +                               size, GL_NONE, NULL, tokens);     param_list->StateFlags |= _mesa_program_state_flags(tokens);     /* free name string here since we duplicated it in add_parameter() */ diff --git a/mesalib/src/mesa/program/programopt.c b/mesalib/src/mesa/program/programopt.c index 389ea218b..2a3702198 100644 --- a/mesalib/src/mesa/program/programopt.c +++ b/mesalib/src/mesa/program/programopt.c @@ -499,9 +499,7 @@ _mesa_count_texture_instructions(struct gl_program *prog)  /**   * Scan/rewrite program to remove reads of custom (output) registers. - * The passed type has to be either PROGRAM_OUTPUT or PROGRAM_VARYING - * (for vertex shaders). - * In GLSL shaders, varying vars can be read and written. + * The passed type has to be PROGRAM_OUTPUT.   * On some hardware, trying to read an output register causes trouble.   * So, rewrite the program to use a temporary register in this case.   */ @@ -517,8 +515,7 @@ _mesa_remove_output_reads(struct gl_program *prog, gl_register_file type)     _mesa_find_used_registers(prog, PROGRAM_TEMPORARY,                               usedTemps, MAX_PROGRAM_TEMPS); -   assert(type == PROGRAM_VARYING || type == PROGRAM_OUTPUT); -   assert(prog->Target == GL_VERTEX_PROGRAM_ARB || type != PROGRAM_VARYING); +   assert(type == PROGRAM_OUTPUT);     for (i = 0; i < VERT_RESULT_MAX; i++)        outputMap[i] = -1; | 
