Subversion Repositories shark

Rev

Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
143 giacomo 1
/* $Id: ss_vbtmp.h,v 1.1 2003-04-29 12:46:52 giacomo Exp $ */
2
 
3
/*
4
 * Mesa 3-D graphics library
5
 * Version:  4.1
6
 *
7
 * Copyright (C) 1999-2002  Brian Paul   All Rights Reserved.
8
 *
9
 * Permission is hereby granted, free of charge, to any person obtaining a
10
 * copy of this software and associated documentation files (the "Software"),
11
 * to deal in the Software without restriction, including without limitation
12
 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
13
 * and/or sell copies of the Software, and to permit persons to whom the
14
 * Software is furnished to do so, subject to the following conditions:
15
 *
16
 * The above copyright notice and this permission notice shall be included
17
 * in all copies or substantial portions of the Software.
18
 *
19
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
20
 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
21
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
22
 * BRIAN PAUL BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
23
 * AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
24
 * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
25
 *
26
 * Authors:
27
 *    Keith Whitwell <keith@tungstengraphics.com>
28
 */
29
 
30
 
31
static void TAG(emit)(GLcontext *ctx, GLuint start, GLuint end,
32
                      GLuint newinputs )
33
{
34
   TNLcontext *tnl = TNL_CONTEXT(ctx);
35
   struct vertex_buffer *VB = &tnl->vb;
36
   SWvertex *v;
37
   GLfloat *proj;               /* projected clip coordinates */
38
   GLfloat *tc[MAX_TEXTURE_UNITS];
39
   GLchan *color;
40
   GLchan *spec;
41
   GLuint *index;
42
   GLfloat *fog;
43
   GLfloat *pointSize;
44
   GLuint tsz[MAX_TEXTURE_UNITS];
45
   GLuint tstride[MAX_TEXTURE_UNITS];
46
   GLuint proj_stride, color_stride, spec_stride, index_stride;
47
   GLuint fog_stride, pointSize_stride;
48
   GLuint i;
49
   GLfloat *m = ctx->Viewport._WindowMap.m;
50
   const GLfloat sx = m[0];
51
   const GLfloat sy = m[5];
52
   const GLfloat sz = m[10];
53
   const GLfloat tx = m[12];
54
   const GLfloat ty = m[13];
55
   const GLfloat tz = m[14];
56
   GLuint maxtex = 0;
57
 
58
   if (IND & TEX0) {
59
      tc[0] = (GLfloat *)VB->TexCoordPtr[0]->data;
60
      tsz[0] = VB->TexCoordPtr[0]->size;
61
      tstride[0] = VB->TexCoordPtr[0]->stride;
62
   }
63
 
64
   if (IND & MULTITEX) {
65
      for (i = 0 ; i < ctx->Const.MaxTextureUnits ; i++) {
66
         if (VB->TexCoordPtr[i]) {
67
            maxtex = i+1;
68
            tc[i] = (GLfloat *)VB->TexCoordPtr[i]->data;
69
            tsz[i] = VB->TexCoordPtr[i]->size;
70
            tstride[i] = VB->TexCoordPtr[i]->stride;
71
         }
72
         else tc[i] = 0;
73
      }
74
   }
75
 
76
   proj = VB->NdcPtr->data[0];
77
   proj_stride = VB->NdcPtr->stride;
78
 
79
   if (IND & FOG) {
80
      fog = (GLfloat *) VB->FogCoordPtr->data;
81
      fog_stride = VB->FogCoordPtr->stride;
82
   }
83
   if (IND & COLOR) {
84
      if (VB->ColorPtr[0]->Type != CHAN_TYPE)
85
         import_float_colors( ctx );
86
 
87
      color = (GLchan *) VB->ColorPtr[0]->Ptr;
88
      color_stride = VB->ColorPtr[0]->StrideB;
89
   }
90
   if (IND & SPEC) {
91
      if (VB->SecondaryColorPtr[0]->Type != CHAN_TYPE)
92
         import_float_spec_colors( ctx );
93
 
94
      spec = (GLchan *) VB->SecondaryColorPtr[0]->Ptr;
95
      spec_stride = VB->SecondaryColorPtr[0]->StrideB;
96
   }
97
   if (IND & INDEX) {
98
      index = VB->IndexPtr[0]->data;
99
      index_stride = VB->IndexPtr[0]->stride;
100
   }
101
   if (IND & POINT) {
102
      pointSize = (GLfloat *) VB->PointSizePtr->data;
103
      pointSize_stride = VB->PointSizePtr->stride;
104
   }
105
 
106
   v = &(SWSETUP_CONTEXT(ctx)->verts[start]);
107
 
108
   for (i=start; i < end; i++, v++) {
109
      if (VB->ClipMask[i] == 0) {
110
         v->win[0] = sx * proj[0] + tx;
111
         v->win[1] = sy * proj[1] + ty;
112
         v->win[2] = sz * proj[2] + tz;
113
         v->win[3] =      proj[3];
114
      }
115
      STRIDE_F(proj, proj_stride);
116
 
117
      if (IND & TEX0) {
118
         COPY_CLEAN_4V( v->texcoord[0], tsz[0], tc[0] );
119
         STRIDE_F(tc[0], tstride[0]);
120
      }
121
 
122
      if (IND & MULTITEX) {
123
         GLuint u;
124
         for (u = 0 ; u < maxtex ; u++)
125
            if (tc[u]) {
126
               COPY_CLEAN_4V( v->texcoord[u], tsz[u], tc[u] );
127
               STRIDE_F(tc[u], tstride[u]);
128
            }
129
      }
130
 
131
      if (IND & COLOR) {
132
         COPY_CHAN4(v->color, color);
133
         STRIDE_CHAN(color, color_stride);
134
      }
135
 
136
      if (IND & SPEC) {
137
         COPY_CHAN4(v->specular, spec);
138
         STRIDE_CHAN(spec, spec_stride);
139
      }
140
 
141
      if (IND & FOG) {
142
         v->fog = fog[0];
143
         STRIDE_F(fog, fog_stride);
144
      }
145
 
146
      if (IND & INDEX) {
147
         v->index = index[0];
148
         STRIDE_UI(index, index_stride);
149
      }
150
 
151
      if (IND & POINT) {
152
         v->pointSize = pointSize[0];
153
         STRIDE_F(pointSize, pointSize_stride);
154
      }
155
   }
156
}
157
 
158
 
159
 
160
static void TAG(interp)( GLcontext *ctx,
161
                         GLfloat t,
162
                         GLuint edst, GLuint eout, GLuint ein,
163
                         GLboolean force_boundary )
164
{
165
   SScontext *swsetup = SWSETUP_CONTEXT(ctx);
166
   struct vertex_buffer *VB = &TNL_CONTEXT(ctx)->vb;
167
   GLfloat *m = ctx->Viewport._WindowMap.m;
168
   GLfloat *clip = VB->ClipPtr->data[edst];
169
 
170
   SWvertex *dst = &swsetup->verts[edst];
171
   SWvertex *in  = &swsetup->verts[ein];
172
   SWvertex *out = &swsetup->verts[eout];
173
 
174
   /* Avoid division by zero by rearranging order of clip planes?
175
    */
176
   if (clip[3] != 0.0) {
177
      GLfloat oow = 1.0F / clip[3];
178
      dst->win[0] = m[0]  * clip[0] * oow + m[12];
179
      dst->win[1] = m[5]  * clip[1] * oow + m[13];
180
      dst->win[2] = m[10] * clip[2] * oow + m[14];
181
      dst->win[3] =                   oow;
182
   }
183
 
184
   if (IND & TEX0) {
185
      INTERP_4F( t, dst->texcoord[0], out->texcoord[0], in->texcoord[0] );
186
   }
187
 
188
   if (IND & MULTITEX) {
189
      GLuint u;
190
      GLuint maxtex = ctx->Const.MaxTextureUnits;
191
      for (u = 0 ; u < maxtex ; u++)
192
         if (VB->TexCoordPtr[u]) {
193
            INTERP_4F( t, dst->texcoord[u], out->texcoord[u], in->texcoord[u] );
194
         }
195
   }
196
 
197
   if (IND & COLOR) {
198
      INTERP_CHAN( t, dst->color[0], out->color[0], in->color[0] );
199
      INTERP_CHAN( t, dst->color[1], out->color[1], in->color[1] );
200
      INTERP_CHAN( t, dst->color[2], out->color[2], in->color[2] );
201
      INTERP_CHAN( t, dst->color[3], out->color[3], in->color[3] );
202
   }
203
 
204
   if (IND & SPEC) {
205
      INTERP_CHAN( t, dst->specular[0], out->specular[0], in->specular[0] );
206
      INTERP_CHAN( t, dst->specular[1], out->specular[1], in->specular[1] );
207
      INTERP_CHAN( t, dst->specular[2], out->specular[2], in->specular[2] );
208
   }
209
 
210
   if (IND & FOG) {
211
      INTERP_F( t, dst->fog, out->fog, in->fog );
212
   }
213
 
214
   if (IND & INDEX) {
215
      INTERP_UI( t, dst->index, out->index, in->index );
216
   }
217
 
218
   /* XXX Point size interpolation??? */
219
   if (IND & POINT) {
220
      INTERP_F( t, dst->pointSize, out->pointSize, in->pointSize );
221
   }
222
}
223
 
224
 
225
static void TAG(copy_pv)( GLcontext *ctx, GLuint edst, GLuint esrc )
226
{
227
   SScontext *swsetup = SWSETUP_CONTEXT(ctx);
228
   SWvertex *dst = &swsetup->verts[edst];
229
   SWvertex *src = &swsetup->verts[esrc];
230
 
231
   if (IND & COLOR) {
232
      COPY_CHAN4( dst->color, src->color );
233
   }
234
 
235
   if (IND & SPEC) {
236
      COPY_3V( dst->specular, src->specular );
237
   }
238
 
239
   if (IND & INDEX) {
240
      dst->index = src->index;
241
   }
242
}
243
 
244
 
245
static void TAG(init)( void )
246
{
247
   setup_tab[IND] = TAG(emit);
248
   interp_tab[IND] = TAG(interp);
249
   copy_pv_tab[IND] = TAG(copy_pv);
250
}
251
 
252
#undef TAG
253
#undef IND
254
#undef SETUP_FLAGS