Compare commits
3 Commits
mesa-17.1.
...
i965-primi
Author | SHA1 | Date | |
---|---|---|---|
|
c7e77fcc31 | ||
|
5a13d321ff | ||
|
c7ecc2e46c |
@@ -46,7 +46,7 @@ GLSL 1.40 missing: UBOS, inverse(),
|
|||||||
highp change
|
highp change
|
||||||
Instanced drawing (GL_ARB_draw_instanced) DONE (i965, gallium, swrast)
|
Instanced drawing (GL_ARB_draw_instanced) DONE (i965, gallium, swrast)
|
||||||
Buffer copying (GL_ARB_copy_buffer) DONE (i965, r300, r600, 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
|
16 vertex texture image units DONE
|
||||||
Texture buffer objs (GL_ARB_texture_buffer_object) needs GL3.1 enabling (i965)
|
Texture buffer objs (GL_ARB_texture_buffer_object) needs GL3.1 enabling (i965)
|
||||||
Rectangular textures (GL_ARB_texture_rectangle) DONE (i965, r300, r600, swrast)
|
Rectangular textures (GL_ARB_texture_rectangle) DONE (i965, r300, r600, swrast)
|
||||||
|
@@ -55,6 +55,7 @@ i965_C_FILES = \
|
|||||||
brw_misc_state.c \
|
brw_misc_state.c \
|
||||||
brw_optimize.c \
|
brw_optimize.c \
|
||||||
brw_program.c \
|
brw_program.c \
|
||||||
|
brw_primitive_restart.c \
|
||||||
brw_queryobj.c \
|
brw_queryobj.c \
|
||||||
brw_sf.c \
|
brw_sf.c \
|
||||||
brw_sf_emit.c \
|
brw_sf_emit.c \
|
||||||
|
@@ -295,6 +295,9 @@ brwCreateContext(int api,
|
|||||||
brw->has_negative_rhw_bug = true;
|
brw->has_negative_rhw_bug = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
brw->prim_restart.in_progress = false;
|
||||||
|
brw->prim_restart.enable_cut_index = false;
|
||||||
|
|
||||||
brw_init_state( brw );
|
brw_init_state( brw );
|
||||||
|
|
||||||
brw->curbe.last_buf = calloc(1, 4096);
|
brw->curbe.last_buf = calloc(1, 4096);
|
||||||
|
@@ -1001,6 +1001,12 @@ struct brw_context
|
|||||||
|
|
||||||
uint32_t render_target_format[MESA_FORMAT_COUNT];
|
uint32_t render_target_format[MESA_FORMAT_COUNT];
|
||||||
bool format_supported_as_render_target[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_SPRITE_POINT_ENABLE 16
|
||||||
|
|
||||||
|
#define BRW_CUT_INDEX_ENABLE (1 << 10)
|
||||||
|
|
||||||
#define BRW_INDEX_BYTE 0
|
#define BRW_INDEX_BYTE 0
|
||||||
#define BRW_INDEX_WORD 1
|
#define BRW_INDEX_WORD 1
|
||||||
#define BRW_INDEX_DWORD 2
|
#define BRW_INDEX_DWORD 2
|
||||||
|
@@ -545,6 +545,12 @@ void brw_draw_prims( struct gl_context *ctx,
|
|||||||
if (!_mesa_check_conditional_render(ctx))
|
if (!_mesa_check_conditional_render(ctx))
|
||||||
return;
|
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 (!vbo_all_varyings_in_vbos(arrays)) {
|
||||||
if (!index_bounds_valid)
|
if (!index_bounds_valid)
|
||||||
vbo_get_minmax_indices(ctx, prim, ib, &min_index, &max_index, nr_prims);
|
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,
|
void brw_init_current_values(struct gl_context *ctx,
|
||||||
struct gl_client_array *arrays);
|
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
|
#endif
|
||||||
|
@@ -851,13 +851,20 @@ static void brw_emit_index_buffer(struct brw_context *brw)
|
|||||||
{
|
{
|
||||||
struct intel_context *intel = &brw->intel;
|
struct intel_context *intel = &brw->intel;
|
||||||
const struct _mesa_index_buffer *index_buffer = brw->ib.ib;
|
const struct _mesa_index_buffer *index_buffer = brw->ib.ib;
|
||||||
|
GLuint cut_index_setting;
|
||||||
|
|
||||||
if (index_buffer == NULL)
|
if (index_buffer == NULL)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
if (brw->prim_restart.enable_cut_index) {
|
||||||
|
cut_index_setting = BRW_CUT_INDEX_ENABLE;
|
||||||
|
} else {
|
||||||
|
cut_index_setting = 0;
|
||||||
|
}
|
||||||
|
|
||||||
BEGIN_BATCH(3);
|
BEGIN_BATCH(3);
|
||||||
OUT_BATCH(CMD_INDEX_BUFFER << 16 |
|
OUT_BATCH(CMD_INDEX_BUFFER << 16 |
|
||||||
/* cut index enable << 10 */
|
cut_index_setting |
|
||||||
get_index_type(index_buffer->type) << 8 |
|
get_index_type(index_buffer->type) << 8 |
|
||||||
1);
|
1);
|
||||||
OUT_RELOC(brw->ib.bo,
|
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")) {
|
else if (driQueryOptionb(&intel->optionCache, "force_s3tc_enable")) {
|
||||||
ctx->Extensions.EXT_texture_compression_s3tc = true;
|
ctx->Extensions.EXT_texture_compression_s3tc = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (intel->gen >= 4) {
|
||||||
|
ctx->Extensions.NV_primitive_restart = true;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user