Compare commits
	
		
			3 Commits
		
	
	
		
			mesa-10.4.
			...
			i965-primi
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 
						 | 
					c7e77fcc31 | ||
| 
						 | 
					5a13d321ff | ||
| 
						 | 
					c7ecc2e46c | 
@@ -46,7 +46,7 @@ GLSL 1.40                                             missing: UBOS, inverse(),
 | 
			
		||||
                                                      highp change
 | 
			
		||||
Instanced drawing (GL_ARB_draw_instanced)             DONE (i965, gallium, swrast)
 | 
			
		||||
Buffer copying (GL_ARB_copy_buffer)                   DONE (i965, r300, r600, swrast)
 | 
			
		||||
Primitive restart (GL_NV_primitive_restart)           DONE (r600)
 | 
			
		||||
Primitive restart (GL_NV_primitive_restart)           DONE (i965, r600)
 | 
			
		||||
16 vertex texture image units                         DONE
 | 
			
		||||
Texture buffer objs (GL_ARB_texture_buffer_object)    needs GL3.1 enabling (i965)
 | 
			
		||||
Rectangular textures (GL_ARB_texture_rectangle)       DONE (i965, r300, r600, swrast)
 | 
			
		||||
 
 | 
			
		||||
@@ -55,6 +55,7 @@ i965_C_FILES = \
 | 
			
		||||
	brw_misc_state.c \
 | 
			
		||||
	brw_optimize.c \
 | 
			
		||||
	brw_program.c \
 | 
			
		||||
	brw_primitive_restart.c \
 | 
			
		||||
	brw_queryobj.c \
 | 
			
		||||
	brw_sf.c \
 | 
			
		||||
	brw_sf_emit.c \
 | 
			
		||||
 
 | 
			
		||||
@@ -295,6 +295,9 @@ brwCreateContext(int api,
 | 
			
		||||
      brw->has_negative_rhw_bug = true;
 | 
			
		||||
   }
 | 
			
		||||
 | 
			
		||||
   brw->prim_restart.in_progress = false;
 | 
			
		||||
   brw->prim_restart.enable_cut_index = false;
 | 
			
		||||
 | 
			
		||||
   brw_init_state( brw );
 | 
			
		||||
 | 
			
		||||
   brw->curbe.last_buf = calloc(1, 4096);
 | 
			
		||||
 
 | 
			
		||||
@@ -1001,6 +1001,12 @@ struct brw_context
 | 
			
		||||
 | 
			
		||||
   uint32_t render_target_format[MESA_FORMAT_COUNT];
 | 
			
		||||
   bool format_supported_as_render_target[MESA_FORMAT_COUNT];
 | 
			
		||||
 | 
			
		||||
   /* PrimitiveRestart */
 | 
			
		||||
   struct {
 | 
			
		||||
      bool in_progress;
 | 
			
		||||
      bool enable_cut_index;
 | 
			
		||||
   } prim_restart;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -167,6 +167,8 @@
 | 
			
		||||
 | 
			
		||||
#define BRW_SPRITE_POINT_ENABLE  16
 | 
			
		||||
 | 
			
		||||
#define BRW_CUT_INDEX_ENABLE     (1 << 10)
 | 
			
		||||
 | 
			
		||||
#define BRW_INDEX_BYTE     0
 | 
			
		||||
#define BRW_INDEX_WORD     1
 | 
			
		||||
#define BRW_INDEX_DWORD    2
 | 
			
		||||
 
 | 
			
		||||
@@ -545,6 +545,12 @@ void brw_draw_prims( struct gl_context *ctx,
 | 
			
		||||
   if (!_mesa_check_conditional_render(ctx))
 | 
			
		||||
      return;
 | 
			
		||||
 | 
			
		||||
   /* Handle primitive restart if needed */
 | 
			
		||||
   if (brw_handle_primitive_restart(ctx, prim, nr_prims, ib)) {
 | 
			
		||||
      /* The draw was handled, so we can exit now */
 | 
			
		||||
      return;
 | 
			
		||||
   }
 | 
			
		||||
 | 
			
		||||
   if (!vbo_all_varyings_in_vbos(arrays)) {
 | 
			
		||||
      if (!index_bounds_valid)
 | 
			
		||||
	 vbo_get_minmax_indices(ctx, prim, ib, &min_index, &max_index, nr_prims);
 | 
			
		||||
 
 | 
			
		||||
@@ -51,4 +51,11 @@ void brw_draw_destroy( struct brw_context *brw );
 | 
			
		||||
void brw_init_current_values(struct gl_context *ctx,
 | 
			
		||||
			     struct gl_client_array *arrays);
 | 
			
		||||
 | 
			
		||||
/* brw_primitive_restart.c */
 | 
			
		||||
GLboolean
 | 
			
		||||
brw_handle_primitive_restart(struct gl_context *ctx,
 | 
			
		||||
                             const struct _mesa_prim *prim,
 | 
			
		||||
                             GLuint nr_prims,
 | 
			
		||||
                             const struct _mesa_index_buffer *ib);
 | 
			
		||||
 | 
			
		||||
#endif
 | 
			
		||||
 
 | 
			
		||||
@@ -851,13 +851,20 @@ static void brw_emit_index_buffer(struct brw_context *brw)
 | 
			
		||||
{
 | 
			
		||||
   struct intel_context *intel = &brw->intel;
 | 
			
		||||
   const struct _mesa_index_buffer *index_buffer = brw->ib.ib;
 | 
			
		||||
   GLuint cut_index_setting;
 | 
			
		||||
 | 
			
		||||
   if (index_buffer == NULL)
 | 
			
		||||
      return;
 | 
			
		||||
 | 
			
		||||
   if (brw->prim_restart.enable_cut_index) {
 | 
			
		||||
      cut_index_setting = BRW_CUT_INDEX_ENABLE;
 | 
			
		||||
   } else {
 | 
			
		||||
      cut_index_setting = 0;
 | 
			
		||||
   }
 | 
			
		||||
 | 
			
		||||
   BEGIN_BATCH(3);
 | 
			
		||||
   OUT_BATCH(CMD_INDEX_BUFFER << 16 |
 | 
			
		||||
             /* cut index enable << 10 */
 | 
			
		||||
             cut_index_setting |
 | 
			
		||||
             get_index_type(index_buffer->type) << 8 |
 | 
			
		||||
             1);
 | 
			
		||||
   OUT_RELOC(brw->ib.bo,
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										166
									
								
								src/mesa/drivers/dri/i965/brw_primitive_restart.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										166
									
								
								src/mesa/drivers/dri/i965/brw_primitive_restart.c
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,166 @@
 | 
			
		||||
/*
 | 
			
		||||
 * Copyright © 2012 Intel Corporation
 | 
			
		||||
 *
 | 
			
		||||
 * Permission is hereby granted, free of charge, to any person obtaining a
 | 
			
		||||
 * copy of this software and associated documentation files (the "Software"),
 | 
			
		||||
 * to deal in the Software without restriction, including without limitation
 | 
			
		||||
 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
 | 
			
		||||
 * and/or sell copies of the Software, and to permit persons to whom the
 | 
			
		||||
 * Software is furnished to do so, subject to the following conditions:
 | 
			
		||||
 *
 | 
			
		||||
 * The above copyright notice and this permission notice (including the next
 | 
			
		||||
 * paragraph) shall be included in all copies or substantial portions of the
 | 
			
		||||
 * Software.
 | 
			
		||||
 *
 | 
			
		||||
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 | 
			
		||||
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 | 
			
		||||
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
 | 
			
		||||
 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 | 
			
		||||
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
 | 
			
		||||
 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
 | 
			
		||||
 * IN THE SOFTWARE.
 | 
			
		||||
 *
 | 
			
		||||
 * Authors:
 | 
			
		||||
 *    Jordan Justen <jordan.l.justen@intel.com>
 | 
			
		||||
 *
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#include "main/imports.h"
 | 
			
		||||
#include "main/bufferobj.h"
 | 
			
		||||
 | 
			
		||||
#include "brw_context.h"
 | 
			
		||||
#include "brw_draw.h"
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Check if the hardware's cut index support can handle the primitive
 | 
			
		||||
 * restart index value.
 | 
			
		||||
 */
 | 
			
		||||
static bool
 | 
			
		||||
can_cut_index_handle_restart_index(struct gl_context *ctx,
 | 
			
		||||
                                   const struct _mesa_index_buffer *ib)
 | 
			
		||||
{
 | 
			
		||||
   bool cut_index_will_work;
 | 
			
		||||
 | 
			
		||||
   switch (ib->type) {
 | 
			
		||||
   case GL_UNSIGNED_BYTE:
 | 
			
		||||
      cut_index_will_work = (ctx->Array.RestartIndex & 0xff) == 0xff;
 | 
			
		||||
      break;
 | 
			
		||||
   case GL_UNSIGNED_SHORT:
 | 
			
		||||
      cut_index_will_work = (ctx->Array.RestartIndex & 0xffff) == 0xffff;
 | 
			
		||||
      break;
 | 
			
		||||
   case GL_UNSIGNED_INT:
 | 
			
		||||
      cut_index_will_work = ctx->Array.RestartIndex == 0xffffffff;
 | 
			
		||||
      break;
 | 
			
		||||
   default:
 | 
			
		||||
      cut_index_will_work = false;
 | 
			
		||||
      assert(0);
 | 
			
		||||
   }
 | 
			
		||||
 | 
			
		||||
   return cut_index_will_work;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Check if the hardware's cut index support can handle the primitive
 | 
			
		||||
 * restart case.
 | 
			
		||||
 */
 | 
			
		||||
static bool
 | 
			
		||||
can_cut_index_handle_prims(struct gl_context *ctx,
 | 
			
		||||
                           const struct _mesa_prim *prim,
 | 
			
		||||
                           GLuint nr_prims,
 | 
			
		||||
                           const struct _mesa_index_buffer *ib)
 | 
			
		||||
{
 | 
			
		||||
   if (!can_cut_index_handle_restart_index(ctx, ib)) {
 | 
			
		||||
      /* The primitive restart index can't be handled, so take
 | 
			
		||||
       * the software path
 | 
			
		||||
       */
 | 
			
		||||
      return false;
 | 
			
		||||
   }
 | 
			
		||||
 | 
			
		||||
   for ( ; nr_prims > 0; nr_prims--) {
 | 
			
		||||
      switch(prim->mode) {
 | 
			
		||||
      case GL_POINTS:
 | 
			
		||||
      case GL_LINES:
 | 
			
		||||
      case GL_LINE_STRIP:
 | 
			
		||||
      case GL_TRIANGLES:
 | 
			
		||||
      case GL_TRIANGLE_STRIP:
 | 
			
		||||
         /* Cut index supports these primitive types */
 | 
			
		||||
         break;
 | 
			
		||||
      default:
 | 
			
		||||
         /* Cut index does not support these primitive types */
 | 
			
		||||
      //case GL_LINE_LOOP:
 | 
			
		||||
      //case GL_TRIANGLE_FAN:
 | 
			
		||||
      //case GL_QUADS:
 | 
			
		||||
      //case GL_QUAD_STRIP:
 | 
			
		||||
      //case GL_POLYGON:
 | 
			
		||||
         return false;
 | 
			
		||||
      }
 | 
			
		||||
   }
 | 
			
		||||
 | 
			
		||||
   return true;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Check if primitive restart is enabled, and if so, handle it properly.
 | 
			
		||||
 *
 | 
			
		||||
 * In some cases the support will be handled in software. When available
 | 
			
		||||
 * hardware will handle primitive restart.
 | 
			
		||||
 */
 | 
			
		||||
GLboolean
 | 
			
		||||
brw_handle_primitive_restart(struct gl_context *ctx,
 | 
			
		||||
                             const struct _mesa_prim *prim,
 | 
			
		||||
                             GLuint nr_prims,
 | 
			
		||||
                             const struct _mesa_index_buffer *ib)
 | 
			
		||||
{
 | 
			
		||||
   struct brw_context *brw = brw_context(ctx);
 | 
			
		||||
 | 
			
		||||
   /* We only need to handle cases where there is an index buffer. */
 | 
			
		||||
   if (ib == NULL) {
 | 
			
		||||
      return GL_FALSE;
 | 
			
		||||
   }
 | 
			
		||||
 | 
			
		||||
   /* If the driver has requested software handling of primitive restarts,
 | 
			
		||||
    * then the VBO module has already taken care of things, and we can
 | 
			
		||||
    * just draw as normal.
 | 
			
		||||
    */
 | 
			
		||||
   if (ctx->Const.PrimitiveRestartInSoftware) {
 | 
			
		||||
      return GL_FALSE;
 | 
			
		||||
   }
 | 
			
		||||
 | 
			
		||||
   /* If we have set the in_progress flag, then we are in the middle
 | 
			
		||||
    * of handling the primitive restart draw.
 | 
			
		||||
    */
 | 
			
		||||
   if (brw->prim_restart.in_progress) {
 | 
			
		||||
      return GL_FALSE;
 | 
			
		||||
   }
 | 
			
		||||
 | 
			
		||||
   /* If PrimitiveRestart is not enabled, then we aren't concerned about
 | 
			
		||||
    * handling this draw.
 | 
			
		||||
    */
 | 
			
		||||
   if (!(ctx->Array.PrimitiveRestart)) {
 | 
			
		||||
      return GL_FALSE;
 | 
			
		||||
   }
 | 
			
		||||
 | 
			
		||||
   /* Signal that we are in the process of handling the
 | 
			
		||||
    * primitive restart draw
 | 
			
		||||
    */
 | 
			
		||||
   brw->prim_restart.in_progress = true;
 | 
			
		||||
 | 
			
		||||
   if (can_cut_index_handle_prims(ctx, prim, nr_prims, ib)) {
 | 
			
		||||
      /* Cut index should work for primitive restart, so use it
 | 
			
		||||
       */
 | 
			
		||||
      brw->prim_restart.enable_cut_index = true;
 | 
			
		||||
      brw_draw_prims(ctx, prim, nr_prims, ib, GL_FALSE, -1, -1, NULL);
 | 
			
		||||
      brw->prim_restart.enable_cut_index = false;
 | 
			
		||||
   } else {
 | 
			
		||||
      /* Not all the primitive draw modes are supported by the cut index,
 | 
			
		||||
       * so take the software path
 | 
			
		||||
       */
 | 
			
		||||
      vbo_sw_primitive_restart(ctx, prim, nr_prims, ib);
 | 
			
		||||
   }
 | 
			
		||||
 | 
			
		||||
   brw->prim_restart.in_progress = false;
 | 
			
		||||
 | 
			
		||||
   /* The primitive restart draw was completed, so return true. */
 | 
			
		||||
   return GL_TRUE;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										4
									
								
								src/mesa/drivers/dri/intel/intel_extensions.c
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										4
									
								
								src/mesa/drivers/dri/intel/intel_extensions.c
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							@@ -167,4 +167,8 @@ intelInitExtensions(struct gl_context *ctx)
 | 
			
		||||
   else if (driQueryOptionb(&intel->optionCache, "force_s3tc_enable")) {
 | 
			
		||||
      ctx->Extensions.EXT_texture_compression_s3tc = true;
 | 
			
		||||
   }
 | 
			
		||||
 | 
			
		||||
   if (intel->gen >= 4) {
 | 
			
		||||
      ctx->Extensions.NV_primitive_restart = true;
 | 
			
		||||
   }
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user