1cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell/*
2cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell * Mesa 3-D graphics library
3a2ea606377ed5679dc513eabcf2d398216b47d61Michal Krol * Version:  6.5
4cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell *
5a2ea606377ed5679dc513eabcf2d398216b47d61Michal Krol * Copyright (C) 1999-2006  Brian Paul   All Rights Reserved.
6cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell *
7cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell * Permission is hereby granted, free of charge, to any person obtaining a
8cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell * copy of this software and associated documentation files (the "Software"),
9cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell * to deal in the Software without restriction, including without limitation
10cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell * the rights to use, copy, modify, merge, publish, distribute, sublicense,
11cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell * and/or sell copies of the Software, and to permit persons to whom the
12cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell * Software is furnished to do so, subject to the following conditions:
13cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell *
14cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell * The above copyright notice and this permission notice shall be included
15cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell * in all copies or substantial portions of the Software.
16cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell *
17cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
18cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
19cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
20cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell * BRIAN PAUL BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
21cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell * AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
22cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
23cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell *
2422144ab7552f0799bcfca506bf4ffa7f70a06649Gareth Hughes * Authors:
2505a4b37707d2c598ea68c05d07a3d65bcbf5a076Brian Paul *    Keith Whitwell <keith@tungstengraphics.com>
26cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell */
27cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell
28cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell
29bbd287103dad776d8a45c87c4e51fbc26d9b80d5Brian Paul#include "main/glheader.h"
30bbd287103dad776d8a45c87c4e51fbc26d9b80d5Brian Paul#include "main/colormac.h"
31bbd287103dad776d8a45c87c4e51fbc26d9b80d5Brian Paul#include "main/macros.h"
32bbd287103dad776d8a45c87c4e51fbc26d9b80d5Brian Paul#include "main/imports.h"
33bbd287103dad776d8a45c87c4e51fbc26d9b80d5Brian Paul#include "main/mtypes.h"
34cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell
35cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell#include "math/m_xform.h"
36cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell
37cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell#include "t_context.h"
38cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell#include "t_pipeline.h"
39cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell
40cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell/* Is there any real benefit seperating texmat from texgen?  It means
41cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell * we need two lots of intermediate storage.  Any changes to
42cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell * _NEW_TEXTURE will invalidate both sets -- it's only on changes to
4322144ab7552f0799bcfca506bf4ffa7f70a06649Gareth Hughes * *only* _NEW_TEXTURE_MATRIX that texgen survives but texmat doesn't.
44cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell *
45cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell * However, the seperation of this code from the complex texgen stuff
46cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell * is very appealing.
47cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell */
48cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwellstruct texmat_stage_data {
49610d59981a9f43fefe29b34ef19c184d28e2bef5Brian Paul   GLvector4f texcoord[MAX_TEXTURE_COORD_UNITS];
50cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell};
51cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell
52b51b0a847d7e7daaea69f77ab569086ef81c24a2Brian Paul#define TEXMAT_STAGE_DATA(stage) ((struct texmat_stage_data *)stage->privatePtr)
53cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell
54cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell
55cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell
56f9995b30756140724f41daf963fa06167912be7fKristian Høgsbergstatic GLboolean run_texmat_stage( struct gl_context *ctx,
57ae0eaf93e092ac8e8b1c98f3e986de96940663faKeith Whitwell				   struct tnl_pipeline_stage *stage )
58cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell{
59cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell   struct texmat_stage_data *store = TEXMAT_STAGE_DATA(stage);
6022144ab7552f0799bcfca506bf4ffa7f70a06649Gareth Hughes   struct vertex_buffer *VB = &TNL_CONTEXT(ctx)->vb;
61cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell   GLuint i;
62cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell
63a328e469d328f8b6fd5afdfc21d576fa1a2c43fcBrian   if (!ctx->Texture._TexMatEnabled || ctx->VertexProgram._Current)
646f973f33679e034b7cb63806f1ddfabdbdd70123Keith Whitwell      return GL_TRUE;
656f973f33679e034b7cb63806f1ddfabdbdd70123Keith Whitwell
66cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell   /* ENABLE_TEXMAT implies that the texture matrix is not the
67cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell    * identity, so we don't have to check that here.
68cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell    */
696f973f33679e034b7cb63806f1ddfabdbdd70123Keith Whitwell   for (i = 0 ; i < ctx->Const.MaxTextureCoordUnits ; i++) {
70ed39a43b8cb2e1cf69b097fc89365cde470ebf51Keith Whitwell      if (ctx->Texture._TexMatEnabled & ENABLE_TEXMAT(i)) {
716f973f33679e034b7cb63806f1ddfabdbdd70123Keith Whitwell	 (void) TransformRaw( &store->texcoord[i],
726f973f33679e034b7cb63806f1ddfabdbdd70123Keith Whitwell			      ctx->TextureMatrixStack[i].Top,
7362e1fae858509615c6e54e0b9388cfa2691a5919Brian Paul			      VB->AttribPtr[_TNL_ATTRIB_TEX0 + i]);
74cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell
7562e1fae858509615c6e54e0b9388cfa2691a5919Brian Paul	 VB->AttribPtr[VERT_ATTRIB_TEX0+i] = &store->texcoord[i];
76cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell      }
776f973f33679e034b7cb63806f1ddfabdbdd70123Keith Whitwell   }
786f973f33679e034b7cb63806f1ddfabdbdd70123Keith Whitwell
79cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell   return GL_TRUE;
80cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell}
81cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell
82cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell
83cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell/* Called the first time stage->run() is invoked.
84cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell */
85f9995b30756140724f41daf963fa06167912be7fKristian Høgsbergstatic GLboolean alloc_texmat_data( struct gl_context *ctx,
86ae0eaf93e092ac8e8b1c98f3e986de96940663faKeith Whitwell				    struct tnl_pipeline_stage *stage )
87cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell{
8822144ab7552f0799bcfca506bf4ffa7f70a06649Gareth Hughes   struct vertex_buffer *VB = &TNL_CONTEXT(ctx)->vb;
89cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell   struct texmat_stage_data *store;
90cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell   GLuint i;
91cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell
92b51b0a847d7e7daaea69f77ab569086ef81c24a2Brian Paul   stage->privatePtr = CALLOC(sizeof(*store));
93cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell   store = TEXMAT_STAGE_DATA(stage);
94cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell   if (!store)
95cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell      return GL_FALSE;
96cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell
9792f9785c727ea10ff5f8dc9770f0e8f388fcea70Brian Paul   for (i = 0 ; i < ctx->Const.MaxTextureCoordUnits ; i++)
9808836341788a9f9d638d9dc8328510ccd18ddeb5Brian Paul      _mesa_vector4f_alloc( &store->texcoord[i], 0, VB->Size, 32 );
99cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell
1006f973f33679e034b7cb63806f1ddfabdbdd70123Keith Whitwell   return GL_TRUE;
101cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell}
102cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell
103cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell
104ae0eaf93e092ac8e8b1c98f3e986de96940663faKeith Whitwellstatic void free_texmat_data( struct tnl_pipeline_stage *stage )
105cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell{
106cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell   struct texmat_stage_data *store = TEXMAT_STAGE_DATA(stage);
107cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell   GLuint i;
108cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell
109cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell   if (store) {
110610d59981a9f43fefe29b34ef19c184d28e2bef5Brian Paul      for (i = 0; i < MAX_TEXTURE_COORD_UNITS; i++)
111cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell	 if (store->texcoord[i].data)
11208836341788a9f9d638d9dc8328510ccd18ddeb5Brian Paul	    _mesa_vector4f_free( &store->texcoord[i] );
113cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell      FREE( store );
114b97e478fe90f612041e27852eb8c95f45467bde8Keith Whitwell      stage->privatePtr = NULL;
115cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell   }
116cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell}
117cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell
118cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell
11922144ab7552f0799bcfca506bf4ffa7f70a06649Gareth Hughes
120ae0eaf93e092ac8e8b1c98f3e986de96940663faKeith Whitwellconst struct tnl_pipeline_stage _tnl_texture_transform_stage =
12122144ab7552f0799bcfca506bf4ffa7f70a06649Gareth Hughes{
12286b842790b720cd6b1499ce8edca8a4e9c8dc029Brian Paul   "texture transform",			/* name */
12386b842790b720cd6b1499ce8edca8a4e9c8dc029Brian Paul   NULL,				/* private data */
1246f973f33679e034b7cb63806f1ddfabdbdd70123Keith Whitwell   alloc_texmat_data,
12586b842790b720cd6b1499ce8edca8a4e9c8dc029Brian Paul   free_texmat_data,			/* destructor */
1266f973f33679e034b7cb63806f1ddfabdbdd70123Keith Whitwell   NULL,
1276f973f33679e034b7cb63806f1ddfabdbdd70123Keith Whitwell   run_texmat_stage,
128cab974cf6c2dbfbf5dd5d291e1aae0f8eeb34290Keith Whitwell};
129