MMX add blending function added.
[mesa.git] / src / mesa / x86 / x86.c
index 3f9d10201b99180fbd111b27f1deb951f58ad0b0..16586b9727df9d245ebe987944fa8c00e5352d43 100644 (file)
@@ -1,10 +1,10 @@
-/* $Id: x86.c,v 1.13 2000/11/22 08:55:53 joukj Exp $ */
+/* $Id: x86.c,v 1.25 2002/04/09 14:58:03 keithw Exp $ */
 
 /*
  * Mesa 3-D graphics library
  * Version:  3.5
  *
- * Copyright (C) 1999  Brian Paul   All Rights Reserved.
+ * Copyright (C) 1999-2001  Brian Paul   All Rights Reserved.
  *
  * Permission is hereby granted, free of charge, to any person obtaining a
  * copy of this software and associated documentation files (the "Software"),
 
 #include "glheader.h"
 #include "context.h"
-#include "mtypes.h"
-#include "x86.h"
-
-#include "math/m_vertices.h"
 #include "math/m_xform.h"
-
 #include "tnl/t_context.h"
 
+#include "x86.h"
+#include "common_x86_macros.h"
+
 #ifdef DEBUG
-#include "math/m_debug_xform.h"
+#include "math/m_debug.h"
 #endif
 
 
-#define XFORM_ARGS     GLvector4f *to_vec,                             \
-                       const GLfloat m[16],                            \
-                       const GLvector4f *from_vec,                     \
-                       const GLubyte *mask,                            \
-                       const GLubyte flag
-
-
-#define DECLARE_XFORM_GROUP( pfx, sz, masked ) \
- extern void _ASMAPI gl_##pfx##_transform_points##sz##_general_##masked( XFORM_ARGS );     \
- extern void _ASMAPI gl_##pfx##_transform_points##sz##_identity_##masked( XFORM_ARGS );            \
- extern void _ASMAPI gl_##pfx##_transform_points##sz##_3d_no_rot_##masked( XFORM_ARGS );    \
- extern void _ASMAPI gl_##pfx##_transform_points##sz##_perspective_##masked( XFORM_ARGS );  \
- extern void _ASMAPI gl_##pfx##_transform_points##sz##_2d_##masked( XFORM_ARGS );          \
- extern void _ASMAPI gl_##pfx##_transform_points##sz##_2d_no_rot_##masked( XFORM_ARGS );    \
- extern void _ASMAPI gl_##pfx##_transform_points##sz##_3d_##masked( XFORM_ARGS );
-
-
-#define ASSIGN_XFORM_GROUP( pfx, cma, sz, masked )                     \
-   gl_transform_tab[cma][sz][MATRIX_GENERAL] =                         \
-      gl_##pfx##_transform_points##sz##_general_##masked;              \
-   gl_transform_tab[cma][sz][MATRIX_IDENTITY] =                                \
-      gl_##pfx##_transform_points##sz##_identity_##masked;             \
-   gl_transform_tab[cma][sz][MATRIX_3D_NO_ROT] =                       \
-      gl_##pfx##_transform_points##sz##_3d_no_rot_##masked;            \
-   gl_transform_tab[cma][sz][MATRIX_PERSPECTIVE] =                     \
-      gl_##pfx##_transform_points##sz##_perspective_##masked;          \
-   gl_transform_tab[cma][sz][MATRIX_2D] =                              \
-      gl_##pfx##_transform_points##sz##_2d_##masked;                   \
-   gl_transform_tab[cma][sz][MATRIX_2D_NO_ROT] =                       \
-      gl_##pfx##_transform_points##sz##_2d_no_rot_##masked;            \
-   gl_transform_tab[cma][sz][MATRIX_3D] =                              \
-      gl_##pfx##_transform_points##sz##_3d_##masked;
-
-
 #ifdef USE_X86_ASM
-DECLARE_XFORM_GROUP( x86, 2, raw )
-DECLARE_XFORM_GROUP( x86, 3, raw )
-DECLARE_XFORM_GROUP( x86, 4, raw )
-DECLARE_XFORM_GROUP( x86, 2, masked )
-DECLARE_XFORM_GROUP( x86, 3, masked )
-DECLARE_XFORM_GROUP( x86, 4, masked )
-
-
-extern GLvector4f * _ASMAPI gl_x86_cliptest_points4( GLvector4f *clip_vec,
-                                                    GLvector4f *proj_vec,
-                                                    GLubyte clipMask[],
-                                                    GLubyte *orMask,
-                                                    GLubyte *andMask );
-
-
-extern void _ASMAPI gl_v16_x86_cliptest_points4( GLfloat *first_vert,
-                                                GLfloat *last_vert,
-                                                GLubyte *or_mask,
-                                                GLubyte *and_mask,
-                                                GLubyte *clip_mask );
-
-
-extern void _ASMAPI gl_v16_x86_general_xform( GLfloat *dest,
-                                             const GLfloat *m,
-                                             const GLfloat *src,
-                                             GLuint src_stride,
-                                             GLuint count );
+DECLARE_XFORM_GROUP( x86, 2 )
+DECLARE_XFORM_GROUP( x86, 3 )
+DECLARE_XFORM_GROUP( x86, 4 )
+
+
+extern GLvector4f * _ASMAPI
+_mesa_x86_cliptest_points4( GLvector4f *clip_vec,
+                           GLvector4f *proj_vec,
+                           GLubyte clipMask[],
+                           GLubyte *orMask,
+                           GLubyte *andMask );
+
+extern GLvector4f * _ASMAPI
+_mesa_x86_cliptest_points4_np( GLvector4f *clip_vec,
+                              GLvector4f *proj_vec,
+                              GLubyte clipMask[],
+                              GLubyte *orMask,
+                              GLubyte *andMask );
+
+extern void _ASMAPI
+_mesa_v16_x86_cliptest_points4( GLfloat *first_vert,
+                               GLfloat *last_vert,
+                               GLubyte *or_mask,
+                               GLubyte *and_mask,
+                               GLubyte *clip_mask );
+
+extern void _ASMAPI
+_mesa_v16_x86_general_xform( GLfloat *dest,
+                            const GLfloat *m,
+                            const GLfloat *src,
+                            GLuint src_stride,
+                            GLuint count );
 #endif
 
 
-void gl_init_x86_transform_asm( void )
+void _mesa_init_x86_transform_asm( void )
 {
 #ifdef USE_X86_ASM
-   ASSIGN_XFORM_GROUP( x86, 0, 2, raw );
-   ASSIGN_XFORM_GROUP( x86, 0, 3, raw );
-   ASSIGN_XFORM_GROUP( x86, 0, 4, raw );
+   ASSIGN_XFORM_GROUP( x86, 2 );
+   ASSIGN_XFORM_GROUP( x86, 3 );
+   ASSIGN_XFORM_GROUP( x86, 4 );
 
-   ASSIGN_XFORM_GROUP( x86, CULL_MASK_ACTIVE, 2, masked );
-   ASSIGN_XFORM_GROUP( x86, CULL_MASK_ACTIVE, 3, masked );
-   ASSIGN_XFORM_GROUP( x86, CULL_MASK_ACTIVE, 4, masked );
-
-   /* XXX this function has been found to cause FP overflow exceptions */
-   gl_clip_tab[4] = gl_x86_cliptest_points4;
+   _mesa_clip_tab[4] = _mesa_x86_cliptest_points4;
+   _mesa_clip_np_tab[4] = _mesa_x86_cliptest_points4_np;
 
 #ifdef DEBUG
-   gl_test_all_transform_functions( "x86" );
+   _math_test_all_transform_functions( "x86" );
+   _math_test_all_cliptest_functions( "x86" );
 #endif
 #endif
 }
 
-void gl_init_x86_vertex_asm( void )
-{
-#ifdef USE_X86_ASM
-   gl_xform_points3_v16_general        = gl_v16_x86_general_xform;
-   gl_cliptest_points4_v16     = gl_v16_x86_cliptest_points4;
-
-#ifdef DEBUG_NOT
-   gl_test_all_vertex_functions( "x86" );
-#endif
-#endif
-}