diff --git a/src/gallium/drivers/virgl/virgl_screen.c b/src/gallium/drivers/virgl/virgl_screen.c index 9ca22ba1d40..31b1c4395f1 100644 --- a/src/gallium/drivers/virgl/virgl_screen.c +++ b/src/gallium/drivers/virgl/virgl_screen.c @@ -355,6 +355,10 @@ virgl_get_param(struct pipe_screen *screen, enum pipe_cap param) return vscreen->caps.caps.v2.capability_bits_v2 & VIRGL_CAP_V2_STRING_MARKER; case PIPE_CAP_SURFACE_SAMPLE_COUNT: return vscreen->caps.caps.v2.capability_bits_v2 & VIRGL_CAP_V2_IMPLICIT_MSAA; + case PIPE_CAP_DRAW_PARAMETERS: + return !!(vscreen->caps.caps.v2.capability_bits_v2 & VIRGL_CAP_V2_DRAW_PARAMETERS); + case PIPE_CAP_SHADER_GROUP_VOTE: + return !!(vscreen->caps.caps.v2.capability_bits_v2 & VIRGL_CAP_V2_GROUP_VOTE); case PIPE_CAP_IMAGE_STORE_FORMATTED: return 1; case PIPE_CAP_MAX_CONSTANT_BUFFER_SIZE_UINT: diff --git a/src/virtio/virtio-gpu/virgl_hw.h b/src/virtio/virtio-gpu/virgl_hw.h index d894e744978..0dd16e72b49 100644 --- a/src/virtio/virtio-gpu/virgl_hw.h +++ b/src/virtio/virtio-gpu/virgl_hw.h @@ -469,6 +469,8 @@ enum virgl_formats { #define VIRGL_CAP_V2_VS_VERTEX_LAYER (1 << 11) #define VIRGL_CAP_V2_VS_VIEWPORT_INDEX (1 << 12) #define VIRGL_CAP_V2_PIPELINE_STATISTICS_QUERY (1 << 13) +#define VIRGL_CAP_V2_DRAW_PARAMETERS (1 << 14) +#define VIRGL_CAP_V2_GROUP_VOTE (1 << 15) /* virgl bind flags - these are compatible with mesa 10.5 gallium. * but are fixed, no other should be passed to virgl either.