summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorIan Romanick <idr@us.ibm.com>2004-09-30 21:18:23 +0000
committerIan Romanick <idr@us.ibm.com>2004-09-30 21:18:23 +0000
commit75e2f0698e6977989e0b4425dbd7b48d35b77450 (patch)
tree34a3ed5508274236b4f65f6e65cc1c87e8978797
parentba467e86fe2a6f6e34221e5f3f718f9c708df1b4 (diff)
Factored out code for setting texture coordinate wrap bits. Added support
for GL_ARB_texture_mirrored_repeat. Enabled GL_NV_blend_square. It has always actually been supported. Removed redundant EXT versions of ARB extension strings.
-rw-r--r--src/mesa/drivers/dri/unichrome/via_context.c6
-rw-r--r--src/mesa/drivers/dri/unichrome/via_state.c65
2 files changed, 47 insertions, 24 deletions
diff --git a/src/mesa/drivers/dri/unichrome/via_context.c b/src/mesa/drivers/dri/unichrome/via_context.c
index a496380c79..4ebf393ac8 100644
--- a/src/mesa/drivers/dri/unichrome/via_context.c
+++ b/src/mesa/drivers/dri/unichrome/via_context.c
@@ -59,7 +59,7 @@
#include <stdio.h>
#include "macros.h"
-#define DRIVER_DATE "20020221"
+#define DRIVER_DATE "20040923"
#include "utils.h"
@@ -263,12 +263,12 @@ static const char * const card_extensions[] =
"GL_ARB_texture_env_add",
"GL_ARB_texture_env_combine", /* John Sheng [2003.7.18] tex combine */
"GL_ARB_texture_env_dot3", /* John Sheng [2003.7.18] tex dot3 */
- "GL_EXT_point_parameters", /* John Sheng [2003.7.18] point param. */
+ "GL_ARB_texture_mirrored_repeat",
"GL_EXT_stencil_wrap",
- "GL_EXT_texture_env_add",
"GL_EXT_texture_env_combine", /* John Sheng [2003.7.18] tex combine */
"GL_EXT_texture_env_dot3", /* John Sheng [2003.7.18] tex dot3 */
"GL_EXT_texture_lod_bias",
+ "GL_NV_blend_square",
NULL
};
diff --git a/src/mesa/drivers/dri/unichrome/via_state.c b/src/mesa/drivers/dri/unichrome/via_state.c
index 44858bd8e0..c8a3234c95 100644
--- a/src/mesa/drivers/dri/unichrome/via_state.c
+++ b/src/mesa/drivers/dri/unichrome/via_state.c
@@ -506,6 +506,44 @@ void viaInitState(GLcontext *ctx)
}
}
+/**
+ * Convert S and T texture coordinate wrap modes to hardware bits.
+ */
+static uint32_t
+get_wrap_mode( GLenum sWrap, GLenum tWrap )
+{
+ uint32_t v = 0;
+
+
+ switch( sWrap ) {
+ case GL_REPEAT:
+ v |= HC_HTXnMPMD_Srepeat;
+ break;
+ case GL_CLAMP:
+ case GL_CLAMP_TO_EDGE:
+ v |= HC_HTXnMPMD_Sclamp;
+ break;
+ case GL_MIRRORED_REPEAT:
+ v |= HC_HTXnMPMD_Smirror;
+ break;
+ }
+
+ switch( tWrap ) {
+ case GL_REPEAT:
+ v |= HC_HTXnMPMD_Trepeat;
+ break;
+ case GL_CLAMP:
+ case GL_CLAMP_TO_EDGE:
+ v |= HC_HTXnMPMD_Tclamp;
+ break;
+ case GL_MIRRORED_REPEAT:
+ v |= HC_HTXnMPMD_Tmirror;
+ break;
+ }
+
+ return v;
+}
+
void viaChooseTextureState(GLcontext *ctx)
{
viaContextPtr vmesa = VIA_CONTEXT(ctx);
@@ -580,17 +618,10 @@ void viaChooseTextureState(GLcontext *ctx)
HC_HTXnFLTe_Nearest;
}
- if (texObj->WrapS == GL_REPEAT)
- vmesa->regHTXnMPMD_0 = HC_HTXnMPMD_Srepeat;
- else
- vmesa->regHTXnMPMD_0 = HC_HTXnMPMD_Sclamp;
+ vmesa->regHTXnMPMD_0 &= ~(HC_HTXnMPMD_SMASK | HC_HTXnMPMD_TMASK);
+ vmesa->regHTXnMPMD_0 |= get_wrap_mode( texObj->WrapS,
+ texObj->WrapT );
- if (GL_TRUE) {
- if (texObj->WrapT == GL_REPEAT)
- vmesa->regHTXnMPMD_0 |= HC_HTXnMPMD_Trepeat;
- else
- vmesa->regHTXnMPMD_0 |= HC_HTXnMPMD_Tclamp;
- }
#ifdef DEBUG
if (VIA_DEBUG) fprintf(stderr, "texUnit0->EnvMode %x\n",texUnit0->EnvMode);
#endif
@@ -3135,17 +3166,9 @@ void viaChooseTextureState(GLcontext *ctx)
break;
}
- if (texObj->WrapS == GL_REPEAT)
- vmesa->regHTXnMPMD_1 = HC_HTXnMPMD_Srepeat;
- else
- vmesa->regHTXnMPMD_1 = HC_HTXnMPMD_Sclamp;
-
- if (GL_TRUE) {
- if (texObj->WrapT == GL_REPEAT)
- vmesa->regHTXnMPMD_1 |= HC_HTXnMPMD_Trepeat;
- else
- vmesa->regHTXnMPMD_1 |= HC_HTXnMPMD_Tclamp;
- }
+ vmesa->regHTXnMPMD_1 &= ~(HC_HTXnMPMD_SMASK | HC_HTXnMPMD_TMASK);
+ vmesa->regHTXnMPMD_1 |= get_wrap_mode( texObj->WrapS,
+ texObj->WrapT );
switch (texUnit1->EnvMode) {
case GL_MODULATE: