mirror of
https://gitlab.freedesktop.org/mesa/mesa.git
synced 2026-05-05 09:38:07 +02:00
llvmpipe: enable PIPE_CAP_QUERY_SO_OVERFLOW
The driver supported this since way before the GL spec for it existed. Just need to support both the per-stream and for all streams variants (which are identical due to only supporting 1 stream). Passes piglit arb_transform_feedback_overflow_query-basic. Reviewed-by: Jose Fonseca <jfonseca@vmware.com>
This commit is contained in:
parent
26d46b94b4
commit
3e96231457
3 changed files with 5 additions and 2 deletions
|
|
@ -232,7 +232,7 @@ GL 4.6, GLSL 4.60
|
|||
GL_ARB_shader_group_vote DONE (i965, nvc0, radeonsi)
|
||||
GL_ARB_spirv_extensions in progress (Nicolai Hähnle, Ian Romanick)
|
||||
GL_ARB_texture_filter_anisotropic not started
|
||||
GL_ARB_transform_feedback_overflow_query DONE (i965/gen6+, radeonsi, softpipe)
|
||||
GL_ARB_transform_feedback_overflow_query DONE (i965/gen6+, radeonsi, llvmpipe, softpipe)
|
||||
GL_KHR_no_error started (Timothy Arceri)
|
||||
|
||||
These are the extensions cherry-picked to make GLES 3.1
|
||||
|
|
|
|||
|
|
@ -155,6 +155,7 @@ llvmpipe_get_query_result(struct pipe_context *pipe,
|
|||
*result = pq->num_primitives_written;
|
||||
break;
|
||||
case PIPE_QUERY_SO_OVERFLOW_PREDICATE:
|
||||
case PIPE_QUERY_SO_OVERFLOW_ANY_PREDICATE:
|
||||
vresult->b = pq->num_primitives_generated > pq->num_primitives_written;
|
||||
break;
|
||||
case PIPE_QUERY_SO_STATISTICS: {
|
||||
|
|
@ -215,6 +216,7 @@ llvmpipe_begin_query(struct pipe_context *pipe, struct pipe_query *q)
|
|||
pq->num_primitives_generated = llvmpipe->so_stats.primitives_storage_needed;
|
||||
break;
|
||||
case PIPE_QUERY_SO_OVERFLOW_PREDICATE:
|
||||
case PIPE_QUERY_SO_OVERFLOW_ANY_PREDICATE:
|
||||
pq->num_primitives_written = llvmpipe->so_stats.num_primitives_written;
|
||||
pq->num_primitives_generated = llvmpipe->so_stats.primitives_storage_needed;
|
||||
break;
|
||||
|
|
@ -264,6 +266,7 @@ llvmpipe_end_query(struct pipe_context *pipe, struct pipe_query *q)
|
|||
llvmpipe->so_stats.primitives_storage_needed - pq->num_primitives_generated;
|
||||
break;
|
||||
case PIPE_QUERY_SO_OVERFLOW_PREDICATE:
|
||||
case PIPE_QUERY_SO_OVERFLOW_ANY_PREDICATE:
|
||||
pq->num_primitives_written =
|
||||
llvmpipe->so_stats.num_primitives_written - pq->num_primitives_written;
|
||||
pq->num_primitives_generated =
|
||||
|
|
|
|||
|
|
@ -270,6 +270,7 @@ llvmpipe_get_param(struct pipe_screen *screen, enum pipe_cap param)
|
|||
case PIPE_CAP_DOUBLES:
|
||||
case PIPE_CAP_INT64:
|
||||
case PIPE_CAP_INT64_DIVMOD:
|
||||
case PIPE_CAP_QUERY_SO_OVERFLOW:
|
||||
return 1;
|
||||
|
||||
case PIPE_CAP_VENDOR_ID:
|
||||
|
|
@ -357,7 +358,6 @@ llvmpipe_get_param(struct pipe_screen *screen, enum pipe_cap param)
|
|||
case PIPE_CAP_POST_DEPTH_COVERAGE:
|
||||
case PIPE_CAP_BINDLESS_TEXTURE:
|
||||
case PIPE_CAP_NIR_SAMPLERS_AS_DEREF:
|
||||
case PIPE_CAP_QUERY_SO_OVERFLOW:
|
||||
case PIPE_CAP_MEMOBJ:
|
||||
return 0;
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue