mirror of
https://gitlab.freedesktop.org/mesa/mesa.git
synced 2025-12-22 17:50:12 +01:00
zink: enable xfb extension in screen creation
switch around the feature enabling as well since extensions need the related feature to also be enabled in order to function fixes mesa/mesa#2868 Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/5163>
This commit is contained in:
parent
e5e657768c
commit
e8ad52f7b0
2 changed files with 27 additions and 3 deletions
|
|
@ -54,7 +54,7 @@ GL 3.0, GLSL 1.30 --- all DONE: freedreno, i965, nv50, nvc0, r600, radeonsi, llv
|
||||||
GL_EXT_draw_buffers2 (Per-buffer blend and masks) DONE (v3d, zink)
|
GL_EXT_draw_buffers2 (Per-buffer blend and masks) DONE (v3d, zink)
|
||||||
GL_EXT_texture_compression_rgtc DONE (zink)
|
GL_EXT_texture_compression_rgtc DONE (zink)
|
||||||
GL_ARB_texture_rg DONE (v3d, zink)
|
GL_ARB_texture_rg DONE (v3d, zink)
|
||||||
GL_EXT_transform_feedback (Transform feedback) DONE (v3d)
|
GL_EXT_transform_feedback (Transform feedback) DONE (v3d, zink)
|
||||||
GL_ARB_vertex_array_object (Vertex array objects) DONE (v3d, zink)
|
GL_ARB_vertex_array_object (Vertex array objects) DONE (v3d, zink)
|
||||||
GL_EXT_framebuffer_sRGB (sRGB framebuffer format) DONE (v3d, zink)
|
GL_EXT_framebuffer_sRGB (sRGB framebuffer format) DONE (v3d, zink)
|
||||||
glClearBuffer commands DONE
|
glClearBuffer commands DONE
|
||||||
|
|
|
||||||
|
|
@ -139,6 +139,12 @@ zink_get_param(struct pipe_screen *pscreen, enum pipe_cap param)
|
||||||
case PIPE_CAP_INDEP_BLEND_FUNC:
|
case PIPE_CAP_INDEP_BLEND_FUNC:
|
||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
|
case PIPE_CAP_MAX_STREAM_OUTPUT_BUFFERS:
|
||||||
|
return screen->have_EXT_transform_feedback ? screen->tf_props.maxTransformFeedbackBuffers : 0;
|
||||||
|
case PIPE_CAP_STREAM_OUTPUT_PAUSE_RESUME:
|
||||||
|
case PIPE_CAP_STREAM_OUTPUT_INTERLEAVE_BUFFERS:
|
||||||
|
return 1;
|
||||||
|
|
||||||
case PIPE_CAP_MAX_TEXTURE_ARRAY_LAYERS:
|
case PIPE_CAP_MAX_TEXTURE_ARRAY_LAYERS:
|
||||||
return screen->props.limits.maxImageArrayLayers;
|
return screen->props.limits.maxImageArrayLayers;
|
||||||
|
|
||||||
|
|
@ -753,7 +759,7 @@ static struct pipe_screen *
|
||||||
zink_internal_create_screen(struct sw_winsys *winsys, int fd)
|
zink_internal_create_screen(struct sw_winsys *winsys, int fd)
|
||||||
{
|
{
|
||||||
struct zink_screen *screen = CALLOC_STRUCT(zink_screen);
|
struct zink_screen *screen = CALLOC_STRUCT(zink_screen);
|
||||||
bool have_cond_render_ext = false;
|
bool have_tf_ext = false, have_cond_render_ext = false;
|
||||||
if (!screen)
|
if (!screen)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
|
|
@ -789,15 +795,24 @@ zink_internal_create_screen(struct sw_winsys *winsys, int fd)
|
||||||
if (!strcmp(extensions[i].extensionName,
|
if (!strcmp(extensions[i].extensionName,
|
||||||
VK_EXT_CONDITIONAL_RENDERING_EXTENSION_NAME))
|
VK_EXT_CONDITIONAL_RENDERING_EXTENSION_NAME))
|
||||||
have_cond_render_ext = true;
|
have_cond_render_ext = true;
|
||||||
|
if (!strcmp(extensions[i].extensionName,
|
||||||
|
VK_EXT_TRANSFORM_FEEDBACK_EXTENSION_NAME))
|
||||||
|
have_tf_ext = true;
|
||||||
|
|
||||||
}
|
}
|
||||||
FREE(extensions);
|
FREE(extensions);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
VkPhysicalDeviceFeatures2 feats = {};
|
VkPhysicalDeviceFeatures2 feats = {};
|
||||||
|
VkPhysicalDeviceTransformFeedbackFeaturesEXT tf_feats = {};
|
||||||
VkPhysicalDeviceConditionalRenderingFeaturesEXT cond_render_feats = {};
|
VkPhysicalDeviceConditionalRenderingFeaturesEXT cond_render_feats = {};
|
||||||
|
|
||||||
feats.sType = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_FEATURES_2;
|
feats.sType = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_FEATURES_2;
|
||||||
|
if (have_tf_ext) {
|
||||||
|
tf_feats.sType = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_TRANSFORM_FEEDBACK_FEATURES_EXT;
|
||||||
|
tf_feats.pNext = feats.pNext;
|
||||||
|
feats.pNext = &tf_feats;
|
||||||
|
}
|
||||||
if (have_cond_render_ext) {
|
if (have_cond_render_ext) {
|
||||||
cond_render_feats.sType = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_CONDITIONAL_RENDERING_FEATURES_EXT;
|
cond_render_feats.sType = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_CONDITIONAL_RENDERING_FEATURES_EXT;
|
||||||
cond_render_feats.pNext = feats.pNext;
|
cond_render_feats.pNext = feats.pNext;
|
||||||
|
|
@ -805,11 +820,18 @@ zink_internal_create_screen(struct sw_winsys *winsys, int fd)
|
||||||
}
|
}
|
||||||
vkGetPhysicalDeviceFeatures2(screen->pdev, &feats);
|
vkGetPhysicalDeviceFeatures2(screen->pdev, &feats);
|
||||||
memcpy(&screen->feats, &feats.features, sizeof(screen->feats));
|
memcpy(&screen->feats, &feats.features, sizeof(screen->feats));
|
||||||
|
if (have_tf_ext && tf_feats.transformFeedback)
|
||||||
|
screen->have_EXT_transform_feedback = true;
|
||||||
if (have_cond_render_ext && cond_render_feats.conditionalRendering)
|
if (have_cond_render_ext && cond_render_feats.conditionalRendering)
|
||||||
screen->have_EXT_conditional_rendering = true;
|
screen->have_EXT_conditional_rendering = true;
|
||||||
|
|
||||||
VkPhysicalDeviceProperties2 props = {};
|
VkPhysicalDeviceProperties2 props = {};
|
||||||
props.sType = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_PROPERTIES_2;
|
props.sType = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_PROPERTIES_2;
|
||||||
|
if (screen->have_EXT_transform_feedback) {
|
||||||
|
screen->tf_props.sType = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_TRANSFORM_FEEDBACK_PROPERTIES_EXT;
|
||||||
|
screen->tf_props.pNext = NULL;
|
||||||
|
props.pNext = &screen->tf_props;
|
||||||
|
}
|
||||||
vkGetPhysicalDeviceProperties2(screen->pdev, &props);
|
vkGetPhysicalDeviceProperties2(screen->pdev, &props);
|
||||||
memcpy(&screen->props, &props.properties, sizeof(screen->props));
|
memcpy(&screen->props, &props.properties, sizeof(screen->props));
|
||||||
|
|
||||||
|
|
@ -833,7 +855,7 @@ zink_internal_create_screen(struct sw_winsys *winsys, int fd)
|
||||||
* this requires us to pass the whole VkPhysicalDeviceFeatures2 struct
|
* this requires us to pass the whole VkPhysicalDeviceFeatures2 struct
|
||||||
*/
|
*/
|
||||||
dci.pNext = &feats;
|
dci.pNext = &feats;
|
||||||
const char *extensions[4] = {
|
const char *extensions[5] = {
|
||||||
VK_KHR_MAINTENANCE1_EXTENSION_NAME,
|
VK_KHR_MAINTENANCE1_EXTENSION_NAME,
|
||||||
};
|
};
|
||||||
num_extensions = 1;
|
num_extensions = 1;
|
||||||
|
|
@ -851,6 +873,8 @@ zink_internal_create_screen(struct sw_winsys *winsys, int fd)
|
||||||
if (screen->have_EXT_conditional_rendering)
|
if (screen->have_EXT_conditional_rendering)
|
||||||
extensions[num_extensions++] = VK_EXT_CONDITIONAL_RENDERING_EXTENSION_NAME;
|
extensions[num_extensions++] = VK_EXT_CONDITIONAL_RENDERING_EXTENSION_NAME;
|
||||||
|
|
||||||
|
if (screen->have_EXT_transform_feedback)
|
||||||
|
extensions[num_extensions++] = VK_EXT_TRANSFORM_FEEDBACK_EXTENSION_NAME;
|
||||||
assert(num_extensions <= ARRAY_SIZE(extensions));
|
assert(num_extensions <= ARRAY_SIZE(extensions));
|
||||||
|
|
||||||
dci.ppEnabledExtensionNames = extensions;
|
dci.ppEnabledExtensionNames = extensions;
|
||||||
|
|
|
||||||
Loading…
Add table
Reference in a new issue