Subversion Repositories shark

Rev

Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
56 pj 1
/* $Id: m_vector.c,v 1.1 2003-02-28 11:48:05 pj Exp $ */
2
 
3
/*
4
 * Mesa 3-D graphics library
5
 * Version:  3.5
6
 *
7
 * Copyright (C) 1999-2001  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
 
27
/*
28
 * New (3.1) transformation code written by Keith Whitwell.
29
 */
30
 
31
 
32
#include "glheader.h"
33
#include "imports.h"
34
#include "macros.h"
35
#include "imports.h"
36
 
37
#include "m_vector.h"
38
 
39
 
40
 
41
/*
42
 * Given a vector [count][4] of floats, set all the [][elt] values
43
 * to 0 (if elt = 0, 1, 2) or 1.0 (if elt = 3).
44
 */
45
void _mesa_vector4f_clean_elem( GLvector4f *vec, GLuint count, GLuint elt )
46
{
47
   static const GLubyte elem_bits[4] = {
48
      VEC_DIRTY_0,
49
      VEC_DIRTY_1,
50
      VEC_DIRTY_2,
51
      VEC_DIRTY_3
52
   };
53
   static const GLfloat clean[4] = { 0, 0, 0, 1 };
54
   const GLfloat v = clean[elt];
55
   GLfloat (*data)[4] = (GLfloat (*)[4])vec->start;
56
   GLuint i;
57
 
58
   for (i = 0 ; i < count ; i++)
59
      data[i][elt] = v;
60
 
61
   vec->flags &= ~elem_bits[elt];
62
}
63
 
64
static const GLubyte size_bits[5] = {
65
   0,
66
   VEC_SIZE_1,
67
   VEC_SIZE_2,
68
   VEC_SIZE_3,
69
   VEC_SIZE_4,
70
};
71
 
72
 
73
 
74
/*
75
 * Initialize GLvector objects.
76
 * Input: v - the vector object to initialize.
77
 *        flags - bitwise-OR of VEC_* flags
78
 *        storage - pointer to storage for the vector's data
79
 */
80
 
81
 
82
void _mesa_vector4f_init( GLvector4f *v, GLuint flags, GLfloat (*storage)[4] )
83
{
84
   v->stride = 4 * sizeof(GLfloat);
85
   v->size = 2;   /* may change: 2-4 for vertices and 1-4 for texcoords */
86
   v->data = storage;
87
   v->start = (GLfloat *) storage;
88
   v->count = 0;
89
   v->flags = size_bits[4] | flags ;
90
}
91
 
92
void _mesa_vector3f_init( GLvector3f *v, GLuint flags, GLfloat (*storage)[3] )
93
{
94
   v->stride = 3 * sizeof(GLfloat);
95
   v->data = storage;
96
   v->start = (GLfloat *) storage;
97
   v->count = 0;
98
   v->flags = flags ;
99
}
100
 
101
void _mesa_vector1f_init( GLvector1f *v, GLuint flags, GLfloat *storage )
102
{
103
   v->stride = 1*sizeof(GLfloat);
104
   v->data = storage;
105
   v->start = (GLfloat *)storage;
106
   v->count = 0;
107
   v->flags = flags ;
108
}
109
 
110
void _mesa_vector4ub_init( GLvector4ub *v, GLuint flags, GLubyte (*storage)[4] )
111
{
112
   v->stride = 4 * sizeof(GLubyte);
113
   v->data = storage;
114
   v->start = (GLubyte *) storage;
115
   v->count = 0;
116
   v->flags = flags ;
117
}
118
 
119
void _mesa_vector4chan_init( GLvector4chan *v, GLuint flags, GLchan (*storage)[4] )
120
{
121
   v->stride = 4 * sizeof(GLchan);
122
   v->data = storage;
123
   v->start = (GLchan *) storage;
124
   v->count = 0;
125
   v->flags = flags ;
126
}
127
 
128
void _mesa_vector4us_init( GLvector4us *v, GLuint flags, GLushort (*storage)[4] )
129
{
130
   v->stride = 4 * sizeof(GLushort);
131
   v->data = storage;
132
   v->start = (GLushort *) storage;
133
   v->count = 0;
134
   v->flags = flags ;
135
}
136
 
137
void _mesa_vector1ub_init( GLvector1ub *v, GLuint flags, GLubyte *storage )
138
{
139
   v->stride = 1 * sizeof(GLubyte);
140
   v->data = storage;
141
   v->start = (GLubyte *) storage;
142
   v->count = 0;
143
   v->flags = flags ;
144
}
145
 
146
void _mesa_vector1ui_init( GLvector1ui *v, GLuint flags, GLuint *storage )
147
{
148
   v->stride = 1 * sizeof(GLuint);
149
   v->data = storage;
150
   v->start = (GLuint *) storage;
151
   v->count = 0;
152
   v->flags = flags ;
153
}
154
 
155
 
156
/*
157
 * Initialize GLvector objects and allocate storage.
158
 * Input: v - the vector object
159
 *        sz - unused????
160
 *        flags - bitwise-OR of VEC_* flags
161
 *        count - number of elements to allocate in vector
162
 *        alignment - desired memory alignment for the data (in bytes)
163
 */
164
 
165
 
166
void _mesa_vector4f_alloc( GLvector4f *v, GLuint flags, GLuint count,
167
                        GLuint alignment )
168
{
169
   v->stride = 4 * sizeof(GLfloat);
170
   v->size = 2;
171
   v->storage = ALIGN_MALLOC( count * 4 * sizeof(GLfloat), alignment );
172
   v->start = (GLfloat *) v->storage;
173
   v->data = (GLfloat (*)[4]) v->storage;
174
   v->count = 0;
175
   v->flags = size_bits[4] | flags | VEC_MALLOC ;
176
}
177
 
178
void _mesa_vector3f_alloc( GLvector3f *v, GLuint flags, GLuint count,
179
                        GLuint alignment )
180
{
181
   v->stride = 3 * sizeof(GLfloat);
182
   v->storage = ALIGN_MALLOC( count * 3 * sizeof(GLfloat), alignment );
183
   v->start = (GLfloat *) v->storage;
184
   v->data = (GLfloat (*)[3]) v->storage;
185
   v->count = 0;
186
   v->flags = flags | VEC_MALLOC ;
187
}
188
 
189
void _mesa_vector1f_alloc( GLvector1f *v, GLuint flags, GLuint count,
190
                        GLuint alignment )
191
{
192
   v->stride = sizeof(GLfloat);
193
   v->storage = v->start = (GLfloat *)
194
      ALIGN_MALLOC( count * sizeof(GLfloat), alignment );
195
   v->data = v->start;
196
   v->count = 0;
197
   v->flags = flags | VEC_MALLOC ;
198
}
199
 
200
void _mesa_vector4ub_alloc( GLvector4ub *v, GLuint flags, GLuint count,
201
                         GLuint alignment )
202
{
203
   v->stride = 4 * sizeof(GLubyte);
204
   v->storage = ALIGN_MALLOC( count * 4 * sizeof(GLubyte), alignment );
205
   v->start = (GLubyte *) v->storage;
206
   v->data = (GLubyte (*)[4]) v->storage;
207
   v->count = 0;
208
   v->flags = flags | VEC_MALLOC ;
209
}
210
 
211
void _mesa_vector4chan_alloc( GLvector4chan *v, GLuint flags, GLuint count,
212
                           GLuint alignment )
213
{
214
   v->stride = 4 * sizeof(GLchan);
215
   v->storage = ALIGN_MALLOC( count * 4 * sizeof(GLchan), alignment );
216
   v->start = (GLchan *) v->storage;
217
   v->data = (GLchan (*)[4]) v->storage;
218
   v->count = 0;
219
   v->flags = flags | VEC_MALLOC ;
220
}
221
 
222
void _mesa_vector4us_alloc( GLvector4us *v, GLuint flags, GLuint count,
223
                         GLuint alignment )
224
{
225
   v->stride = 4 * sizeof(GLushort);
226
   v->storage = ALIGN_MALLOC( count * 4 * sizeof(GLushort), alignment );
227
   v->start = (GLushort *) v->storage;
228
   v->data = (GLushort (*)[4]) v->storage;
229
   v->count = 0;
230
   v->flags = flags | VEC_MALLOC ;
231
}
232
 
233
void _mesa_vector1ub_alloc( GLvector1ub *v, GLuint flags, GLuint count,
234
                         GLuint alignment )
235
{
236
   v->stride = 1 * sizeof(GLubyte);
237
   v->storage = ALIGN_MALLOC( count * sizeof(GLubyte), alignment );
238
   v->start = (GLubyte *) v->storage;
239
   v->data = (GLubyte *) v->storage;
240
   v->count = 0;
241
   v->flags = flags | VEC_MALLOC ;
242
}
243
 
244
void _mesa_vector1ui_alloc( GLvector1ui *v, GLuint flags, GLuint count,
245
                         GLuint alignment )
246
{
247
   v->stride = 1 * sizeof(GLuint);
248
   v->storage = ALIGN_MALLOC( count * sizeof(GLuint), alignment );
249
   v->start = (GLuint *) v->storage;
250
   v->data = (GLuint *) v->storage;
251
   v->count = 0;
252
   v->flags = flags | VEC_MALLOC ;
253
}
254
 
255
 
256
 
257
/*
258
 * Vector deallocation.  Free whatever memory is pointed to by the
259
 * vector's storage field if the VEC_MALLOC flag is set.
260
 * DO NOT free the GLvector object itself, though.
261
 */
262
 
263
 
264
void _mesa_vector4f_free( GLvector4f *v )
265
{
266
   if (v->flags & VEC_MALLOC) {
267
      ALIGN_FREE( v->storage );
268
      v->data = NULL;
269
      v->start = NULL;
270
      v->storage = NULL;
271
      v->flags &= ~VEC_MALLOC;
272
   }
273
}
274
 
275
void _mesa_vector3f_free( GLvector3f *v )
276
{
277
   if (v->flags & VEC_MALLOC) {
278
      ALIGN_FREE( v->storage );
279
      v->data = 0;
280
      v->start = 0;
281
      v->storage = 0;
282
      v->flags &= ~VEC_MALLOC;
283
   }
284
}
285
 
286
void _mesa_vector1f_free( GLvector1f *v )
287
{
288
   if (v->flags & VEC_MALLOC) {
289
      ALIGN_FREE( v->storage );
290
      v->data = NULL;
291
      v->start = NULL;
292
      v->storage = NULL;
293
      v->flags &= ~VEC_MALLOC;
294
   }
295
}
296
 
297
void _mesa_vector4ub_free( GLvector4ub *v )
298
{
299
   if (v->flags & VEC_MALLOC) {
300
      ALIGN_FREE( v->storage );
301
      v->data = NULL;
302
      v->start = NULL;
303
      v->storage = NULL;
304
      v->flags &= ~VEC_MALLOC;
305
   }
306
}
307
 
308
void _mesa_vector4chan_free( GLvector4chan *v )
309
{
310
   if (v->flags & VEC_MALLOC) {
311
      ALIGN_FREE( v->storage );
312
      v->data = NULL;
313
      v->start = NULL;
314
      v->storage = NULL;
315
      v->flags &= ~VEC_MALLOC;
316
   }
317
}
318
 
319
void _mesa_vector4us_free( GLvector4us *v )
320
{
321
   if (v->flags & VEC_MALLOC) {
322
      ALIGN_FREE( v->storage );
323
      v->data = NULL;
324
      v->start = NULL;
325
      v->storage = NULL;
326
      v->flags &= ~VEC_MALLOC;
327
   }
328
}
329
 
330
void _mesa_vector1ub_free( GLvector1ub *v )
331
{
332
   if (v->flags & VEC_MALLOC) {
333
      ALIGN_FREE( v->storage );
334
      v->data = NULL;
335
      v->start = NULL;
336
      v->storage = NULL;
337
      v->flags &= ~VEC_MALLOC;
338
   }
339
}
340
 
341
void _mesa_vector1ui_free( GLvector1ui *v )
342
{
343
   if (v->flags & VEC_MALLOC) {
344
      ALIGN_FREE( v->storage );
345
      v->data = NULL;
346
      v->start = NULL;
347
      v->storage = NULL;
348
      v->flags &= ~VEC_MALLOC;
349
   }
350
}
351
 
352
 
353
/*
354
 * For debugging
355
 */
356
void _mesa_vector4f_print( GLvector4f *v, GLubyte *cullmask, GLboolean culling )
357
{
358
   GLfloat c[4] = { 0, 0, 0, 1 };
359
   const char *templates[5] = {
360
      "%d:\t0, 0, 0, 1\n",
361
      "%d:\t%f, 0, 0, 1\n",
362
      "%d:\t%f, %f, 0, 1\n",
363
      "%d:\t%f, %f, %f, 1\n",
364
      "%d:\t%f, %f, %f, %f\n"
365
   };
366
 
367
   const char *t = templates[v->size];
368
   GLfloat *d = (GLfloat *)v->data;
369
   GLuint j, i = 0, count;
370
 
371
   _mesa_printf(NULL, "data-start\n");
372
   for ( ; d != v->start ; STRIDE_F(d, v->stride), i++)
373
      _mesa_printf(NULL, t, i, d[0], d[1], d[2], d[3]);
374
 
375
   _mesa_printf(NULL, "start-count(%u)\n", v->count);
376
   count = i + v->count;
377
 
378
   if (culling) {
379
      for ( ; i < count ; STRIDE_F(d, v->stride), i++)
380
         if (cullmask[i])
381
            _mesa_printf(NULL, t, i, d[0], d[1], d[2], d[3]);
382
   }
383
   else {
384
      for ( ; i < count ; STRIDE_F(d, v->stride), i++)
385
         _mesa_printf(NULL, t, i, d[0], d[1], d[2], d[3]);
386
   }
387
 
388
   for (j = v->size ; j < 4; j++) {
389
      if ((v->flags & (1<<j)) == 0) {
390
 
391
         _mesa_printf(NULL, "checking col %u is clean as advertised ", j);
392
 
393
         for (i = 0, d = (GLfloat *) v->data ;
394
              i < count && d[j] == c[j] ;
395
              i++, STRIDE_F(d, v->stride)) {};
396
 
397
         if (i == count)
398
            _mesa_printf(NULL, " --> ok\n");
399
         else
400
            _mesa_printf(NULL, " --> Failed at %u ******\n", i);
401
      }
402
   }
403
}
404
 
405
 
406
/*
407
 * For debugging
408
 */
409
void _mesa_vector3f_print( GLvector3f *v, GLubyte *cullmask, GLboolean culling )
410
{
411
   GLfloat *d = (GLfloat *)v->data;
412
   GLuint i = 0, count;
413
 
414
   _mesa_printf(NULL, "data-start\n");
415
   for ( ; d != v->start ; STRIDE_F(d,v->stride), i++)
416
      _mesa_printf(NULL,  "%u:\t%f, %f, %f\n", i, d[0], d[1], d[2]);
417
 
418
   _mesa_printf(NULL, "start-count(%u)\n", v->count);
419
   count = i + v->count;
420
 
421
   if (culling) {
422
      for ( ; i < count ; STRIDE_F(d,v->stride), i++)
423
         if (cullmask[i])
424
            _mesa_printf(NULL, "%u:\t%f, %f, %f\n", i, d[0], d[1], d[2]);
425
   }
426
   else {
427
      for ( ; i < count ; STRIDE_F(d,v->stride), i++)
428
         _mesa_printf(NULL, "%u:\t%f, %f, %f\n", i, d[0], d[1], d[2]);
429
   }
430
}