blob: 8f02f228770ee9bc577fb44ff24613d566da7b13 [file] [log] [blame]
Michal Krol2861e732004-03-29 11:09:34 +00001/*
2 * Mesa 3-D graphics library
3 * Version: 5.1
4 *
5 * Copyright (C) 1999-2003 Brian Paul All Rights Reserved.
6 *
7 * Permission is hereby granted, free of charge, to any person obtaining a
8 * copy of this software and associated documentation files (the "Software"),
9 * to deal in the Software without restriction, including without limitation
10 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
11 * and/or sell copies of the Software, and to permit persons to whom the
12 * Software is furnished to do so, subject to the following conditions:
13 *
14 * The above copyright notice and this permission notice shall be included
15 * in all copies or substantial portions of the Software.
16 *
17 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
18 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
19 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
20 * BRIAN PAUL BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
21 * AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
22 * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
23 */
24
25
26/* Private fragment program types and constants only used by files
27 * related to fragment programs.
28 *
29 * XXX TO-DO: Rename this file "fragprog.h" since it's not NV-specific.
30 */
31
32
33#ifndef NVFRAGPROG_H
34#define NVFRAGPROG_H
35
36#include "config.h"
37
38
39/* output registers */
40#define FRAG_OUTPUT_COLR 0
41#define FRAG_OUTPUT_COLH 1
42#define FRAG_OUTPUT_DEPR 2
43
44
45/* condition codes */
46#define COND_GT 1 /* greater than zero */
47#define COND_EQ 2 /* equal to zero */
48#define COND_LT 3 /* less than zero */
49#define COND_UN 4 /* unordered (NaN) */
50#define COND_GE 5 /* greater then or equal to zero */
51#define COND_LE 6 /* less then or equal to zero */
52#define COND_NE 7 /* not equal to zero */
53#define COND_TR 8 /* always true */
54#define COND_FL 9 /* always false */
55
56
57/* instruction precision */
58#define FLOAT32 0x1
59#define FLOAT16 0x2
60#define FIXED12 0x4
61
62
63/* Fragment program instruction opcodes */
64enum fp_opcode {
Brian Paula6c423d2004-08-25 15:59:48 +000065 FP_OPCODE_INVALID = -1, /* Force signed enum */
Michal Krol2861e732004-03-29 11:09:34 +000066 FP_OPCODE_ABS = 1000, /* ARB_f_p only */
67 FP_OPCODE_ADD,
68 FP_OPCODE_CMP, /* ARB_f_p only */
69 FP_OPCODE_COS,
70 FP_OPCODE_DDX, /* NV_f_p only */
71 FP_OPCODE_DDY, /* NV_f_p only */
72 FP_OPCODE_DP3,
73 FP_OPCODE_DP4,
74 FP_OPCODE_DPH, /* ARB_f_p only */
75 FP_OPCODE_DST,
76 FP_OPCODE_EX2,
77 FP_OPCODE_FLR,
78 FP_OPCODE_FRC,
Brian Paulff1a0152004-04-02 17:27:46 +000079 FP_OPCODE_KIL_NV, /* NV_f_p only */
80 FP_OPCODE_KIL, /* ARB_f_p only */
Michal Krol2861e732004-03-29 11:09:34 +000081 FP_OPCODE_LG2,
82 FP_OPCODE_LIT,
83 FP_OPCODE_LRP,
84 FP_OPCODE_MAD,
85 FP_OPCODE_MAX,
86 FP_OPCODE_MIN,
87 FP_OPCODE_MOV,
88 FP_OPCODE_MUL,
89 FP_OPCODE_PK2H, /* NV_f_p only */
90 FP_OPCODE_PK2US, /* NV_f_p only */
91 FP_OPCODE_PK4B, /* NV_f_p only */
92 FP_OPCODE_PK4UB, /* NV_f_p only */
93 FP_OPCODE_POW,
94 FP_OPCODE_RCP,
95 FP_OPCODE_RFL, /* NV_f_p only */
96 FP_OPCODE_RSQ,
97 FP_OPCODE_SCS, /* ARB_f_p only */
98 FP_OPCODE_SEQ, /* NV_f_p only */
99 FP_OPCODE_SFL, /* NV_f_p only */
100 FP_OPCODE_SGE, /* NV_f_p only */
101 FP_OPCODE_SGT, /* NV_f_p only */
102 FP_OPCODE_SIN,
103 FP_OPCODE_SLE, /* NV_f_p only */
104 FP_OPCODE_SLT,
105 FP_OPCODE_SNE, /* NV_f_p only */
106 FP_OPCODE_STR, /* NV_f_p only */
107 FP_OPCODE_SUB,
108 FP_OPCODE_SWZ, /* ARB_f_p only */
109 FP_OPCODE_TEX,
110 FP_OPCODE_TXB, /* ARB_f_p only */
111 FP_OPCODE_TXD, /* NV_f_p only */
Brian Pauld8b82142004-04-18 20:11:52 +0000112 FP_OPCODE_TXP, /* ARB_f_p only */
113 FP_OPCODE_TXP_NV, /* NV_f_p only */
Michal Krol2861e732004-03-29 11:09:34 +0000114 FP_OPCODE_UP2H, /* NV_f_p only */
115 FP_OPCODE_UP2US, /* NV_f_p only */
116 FP_OPCODE_UP4B, /* NV_f_p only */
117 FP_OPCODE_UP4UB, /* NV_f_p only */
Keith Whitwelleeb5eeb2004-03-29 16:01:18 +0000118 FP_OPCODE_X2D, /* NV_f_p only - 2d mat mul */
119 FP_OPCODE_XPD, /* ARB_f_p only - cross product */
Michal Krol2861e732004-03-29 11:09:34 +0000120 FP_OPCODE_END /* private opcode */
121};
122
123
124/* Instruction source register */
125struct fp_src_register
126{
127 enum register_file File;
128 GLint Index;
129 GLuint Swizzle[4];
130 GLboolean NegateBase; /* negate before absolute value? */
131 GLboolean Abs; /* take absolute value? */
132 GLboolean NegateAbs; /* negate after absolute value? */
133};
134
135
136/* Instruction destination register */
137struct fp_dst_register
138{
139 enum register_file File;
140 GLint Index;
141 GLboolean WriteMask[4];
142 GLuint CondMask;
143 GLuint CondSwizzle[4];
144};
145
146
147/* Fragment program instruction */
148struct fp_instruction
149{
150 enum fp_opcode Opcode;
151 struct fp_src_register SrcReg[3];
152 struct fp_dst_register DstReg;
153 GLboolean Saturate;
154 GLboolean UpdateCondRegister;
155 GLubyte Precision; /* FLOAT32, FLOAT16 or FIXED12 */
156 GLubyte TexSrcUnit; /* texture unit for TEX, TXD, TXP instructions */
157 GLubyte TexSrcBit; /* TEXTURE_1D,2D,3D,CUBE,RECT_BIT source target */
158#if FEATURE_MESA_program_debug
159 GLint StringPos;
160#endif
161};
162
163
164#endif