mirror of
https://gitlab.freedesktop.org/monado/monado.git
synced 2025-01-19 13:18:32 +00:00
c/util: Propagate some Vulkan errors
This commit is contained in:
parent
9e5c0d72e1
commit
b3d4ee2186
|
@ -7,19 +7,24 @@
|
||||||
* @ingroup comp_util
|
* @ingroup comp_util
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include "xrt/xrt_compiler.h"
|
||||||
#include "xrt/xrt_handles.h"
|
#include "xrt/xrt_handles.h"
|
||||||
#include "xrt/xrt_config_os.h"
|
#include "xrt/xrt_config_os.h"
|
||||||
|
#include "xrt/xrt_results.h"
|
||||||
|
|
||||||
#include "util/u_misc.h"
|
#include "util/u_misc.h"
|
||||||
#include "util/u_handles.h"
|
#include "util/u_handles.h"
|
||||||
#include "util/u_trace_marker.h"
|
#include "util/u_trace_marker.h"
|
||||||
#include "util/u_limited_unique_id.h"
|
#include "util/u_limited_unique_id.h"
|
||||||
|
|
||||||
|
#include "vk/vk_helpers.h"
|
||||||
#include "vk/vk_cmd_pool.h"
|
#include "vk/vk_cmd_pool.h"
|
||||||
#include "vk/vk_mini_helpers.h"
|
#include "vk/vk_mini_helpers.h"
|
||||||
|
|
||||||
#include "util/comp_swapchain.h"
|
#include "util/comp_swapchain.h"
|
||||||
|
|
||||||
|
#include "util/comp_swapchain.h"
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <inttypes.h>
|
#include <inttypes.h>
|
||||||
|
@ -290,10 +295,22 @@ image_cleanup(struct vk_bundle *vk, struct comp_swapchain_image *image)
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
cleanup_post_create_vulkan_setup(struct vk_bundle *vk, struct comp_swapchain *sc)
|
||||||
|
{
|
||||||
|
|
||||||
|
uint32_t image_count = sc->vkic.image_count;
|
||||||
|
|
||||||
|
for (uint32_t i = 0; i < image_count; i++) {
|
||||||
|
image_cleanup(vk, &(sc->images[i]));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static XRT_CHECK_RESULT xrt_result_t
|
||||||
do_post_create_vulkan_setup(struct vk_bundle *vk,
|
do_post_create_vulkan_setup(struct vk_bundle *vk,
|
||||||
const struct xrt_swapchain_create_info *info,
|
const struct xrt_swapchain_create_info *info,
|
||||||
struct comp_swapchain *sc)
|
struct comp_swapchain *sc)
|
||||||
{
|
{
|
||||||
|
xrt_result_t xret = XRT_SUCCESS;
|
||||||
uint32_t image_count = sc->vkic.image_count;
|
uint32_t image_count = sc->vkic.image_count;
|
||||||
VkCommandBuffer cmd_buffer;
|
VkCommandBuffer cmd_buffer;
|
||||||
VkResult ret;
|
VkResult ret;
|
||||||
|
@ -314,6 +331,11 @@ do_post_create_vulkan_setup(struct vk_bundle *vk,
|
||||||
for (uint32_t i = 0; i < image_count; i++) {
|
for (uint32_t i = 0; i < image_count; i++) {
|
||||||
sc->images[i].views.alpha = U_TYPED_ARRAY_CALLOC(VkImageView, info->array_size);
|
sc->images[i].views.alpha = U_TYPED_ARRAY_CALLOC(VkImageView, info->array_size);
|
||||||
sc->images[i].views.no_alpha = U_TYPED_ARRAY_CALLOC(VkImageView, info->array_size);
|
sc->images[i].views.no_alpha = U_TYPED_ARRAY_CALLOC(VkImageView, info->array_size);
|
||||||
|
if (!sc->images[i].views.alpha || !sc->images[i].views.no_alpha) {
|
||||||
|
cleanup_post_create_vulkan_setup(vk, sc);
|
||||||
|
//! @todo actually out of memory
|
||||||
|
return XRT_ERROR_VULKAN;
|
||||||
|
}
|
||||||
sc->images[i].array_size = info->array_size;
|
sc->images[i].array_size = info->array_size;
|
||||||
|
|
||||||
for (uint32_t layer = 0; layer < info->array_size; ++layer) {
|
for (uint32_t layer = 0; layer < info->array_size; ++layer) {
|
||||||
|
@ -325,7 +347,7 @@ do_post_create_vulkan_setup(struct vk_bundle *vk,
|
||||||
.layerCount = info->face_count,
|
.layerCount = info->face_count,
|
||||||
};
|
};
|
||||||
|
|
||||||
vk_create_view( //
|
ret = vk_create_view( //
|
||||||
vk, // vk
|
vk, // vk
|
||||||
sc->vkic.images[i].handle, // image
|
sc->vkic.images[i].handle, // image
|
||||||
image_view_type, // type
|
image_view_type, // type
|
||||||
|
@ -333,9 +355,11 @@ do_post_create_vulkan_setup(struct vk_bundle *vk,
|
||||||
subresource_range, // subresource_range
|
subresource_range, // subresource_range
|
||||||
&sc->images[i].views.alpha[layer]); // out_view
|
&sc->images[i].views.alpha[layer]); // out_view
|
||||||
|
|
||||||
|
VK_CHK_WITH_GOTO(ret, "vk_create_view", error);
|
||||||
|
|
||||||
VK_NAME_IMAGE_VIEW(vk, sc->images[i].views.alpha[layer], "comp_swapchain views alpha layer");
|
VK_NAME_IMAGE_VIEW(vk, sc->images[i].views.alpha[layer], "comp_swapchain views alpha layer");
|
||||||
|
|
||||||
vk_create_view_swizzle( //
|
ret = vk_create_view_swizzle( //
|
||||||
vk, // vk
|
vk, // vk
|
||||||
sc->vkic.images[i].handle, // image
|
sc->vkic.images[i].handle, // image
|
||||||
image_view_type, // type
|
image_view_type, // type
|
||||||
|
@ -344,6 +368,8 @@ do_post_create_vulkan_setup(struct vk_bundle *vk,
|
||||||
components, // components
|
components, // components
|
||||||
&sc->images[i].views.no_alpha[layer]); // out_view
|
&sc->images[i].views.no_alpha[layer]); // out_view
|
||||||
|
|
||||||
|
VK_CHK_WITH_GOTO(ret, "vk_create_view_swizzle", error);
|
||||||
|
|
||||||
VK_NAME_IMAGE_VIEW(vk, sc->images[i].views.no_alpha[layer],
|
VK_NAME_IMAGE_VIEW(vk, sc->images[i].views.no_alpha[layer],
|
||||||
"comp_swapchain views no alpha layer");
|
"comp_swapchain views no alpha layer");
|
||||||
}
|
}
|
||||||
|
@ -370,9 +396,10 @@ do_post_create_vulkan_setup(struct vk_bundle *vk,
|
||||||
// Now lets create the command buffer.
|
// Now lets create the command buffer.
|
||||||
ret = vk_cmd_pool_create_and_begin_cmd_buffer_locked(vk, pool, 0, &cmd_buffer);
|
ret = vk_cmd_pool_create_and_begin_cmd_buffer_locked(vk, pool, 0, &cmd_buffer);
|
||||||
if (ret != VK_SUCCESS) {
|
if (ret != VK_SUCCESS) {
|
||||||
vk_cmd_pool_unlock(pool);
|
|
||||||
VK_ERROR(vk, "Failed to barrier images");
|
VK_ERROR(vk, "Failed to barrier images");
|
||||||
return;
|
vk_cmd_pool_unlock(pool);
|
||||||
|
cleanup_post_create_vulkan_setup(vk, sc);
|
||||||
|
return XRT_ERROR_VULKAN;
|
||||||
}
|
}
|
||||||
|
|
||||||
VK_NAME_COMMAND_BUFFER(vk, cmd_buffer, "comp_swapchain command buffer");
|
VK_NAME_COMMAND_BUFFER(vk, cmd_buffer, "comp_swapchain command buffer");
|
||||||
|
@ -407,8 +434,9 @@ do_post_create_vulkan_setup(struct vk_bundle *vk,
|
||||||
|
|
||||||
// Check results from submit.
|
// Check results from submit.
|
||||||
if (ret != VK_SUCCESS) {
|
if (ret != VK_SUCCESS) {
|
||||||
//! @todo Propegate error
|
|
||||||
VK_ERROR(vk, "Failed to barrier images");
|
VK_ERROR(vk, "Failed to barrier images");
|
||||||
|
cleanup_post_create_vulkan_setup(vk, sc);
|
||||||
|
return XRT_ERROR_VULKAN;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (uint32_t i = 0; i < image_count; i++) {
|
for (uint32_t i = 0; i < image_count; i++) {
|
||||||
|
@ -416,17 +444,25 @@ do_post_create_vulkan_setup(struct vk_bundle *vk,
|
||||||
ret = pthread_cond_init(&sc->images[i].use_cond, NULL);
|
ret = pthread_cond_init(&sc->images[i].use_cond, NULL);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
VK_ERROR(sc->vk, "Failed to init image use cond: %d", ret);
|
VK_ERROR(sc->vk, "Failed to init image use cond: %d", ret);
|
||||||
|
xret = XRT_ERROR_THREADING_INIT_FAILURE;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = os_mutex_init(&sc->images[i].use_mutex);
|
ret = os_mutex_init(&sc->images[i].use_mutex);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
VK_ERROR(sc->vk, "Failed to init image use mutex: %d", ret);
|
VK_ERROR(sc->vk, "Failed to init image use mutex: %d", ret);
|
||||||
|
xret = XRT_ERROR_THREADING_INIT_FAILURE;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
sc->images[i].use_count = 0;
|
sc->images[i].use_count = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return xret;
|
||||||
|
|
||||||
|
error:
|
||||||
|
cleanup_post_create_vulkan_setup(vk, sc);
|
||||||
|
return XRT_ERROR_VULKAN;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
|
@ -490,14 +526,25 @@ comp_swapchain_create_init(struct comp_swapchain *sc,
|
||||||
|
|
||||||
xrt_graphics_buffer_handle_t handles[ARRAY_SIZE(sc->vkic.images)];
|
xrt_graphics_buffer_handle_t handles[ARRAY_SIZE(sc->vkic.images)];
|
||||||
|
|
||||||
vk_ic_get_handles(vk, &sc->vkic, ARRAY_SIZE(handles), handles);
|
ret = vk_ic_get_handles(vk, &sc->vkic, ARRAY_SIZE(handles), handles);
|
||||||
|
if (ret != VK_SUCCESS) {
|
||||||
|
VK_ERROR(vk, "Failed to get native handles for images.");
|
||||||
|
vk_ic_destroy(vk, &sc->vkic);
|
||||||
|
free(sc);
|
||||||
|
return XRT_ERROR_VULKAN;
|
||||||
|
}
|
||||||
for (uint32_t i = 0; i < sc->vkic.image_count; i++) {
|
for (uint32_t i = 0; i < sc->vkic.image_count; i++) {
|
||||||
sc->base.images[i].handle = handles[i];
|
sc->base.images[i].handle = handles[i];
|
||||||
sc->base.images[i].size = sc->vkic.images[i].size;
|
sc->base.images[i].size = sc->vkic.images[i].size;
|
||||||
sc->base.images[i].use_dedicated_allocation = sc->vkic.images[i].use_dedicated_allocation;
|
sc->base.images[i].use_dedicated_allocation = sc->vkic.images[i].use_dedicated_allocation;
|
||||||
}
|
}
|
||||||
|
|
||||||
do_post_create_vulkan_setup(vk, info, sc);
|
xrt_result_t res = do_post_create_vulkan_setup(vk, info, sc);
|
||||||
|
if (res != XRT_SUCCESS) {
|
||||||
|
vk_ic_destroy(vk, &sc->vkic);
|
||||||
|
free(sc);
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
return XRT_SUCCESS;
|
return XRT_SUCCESS;
|
||||||
}
|
}
|
||||||
|
@ -526,7 +573,12 @@ comp_swapchain_import_init(struct comp_swapchain *sc,
|
||||||
return XRT_ERROR_VULKAN;
|
return XRT_ERROR_VULKAN;
|
||||||
}
|
}
|
||||||
|
|
||||||
do_post_create_vulkan_setup(vk, info, sc);
|
xrt_result_t res = do_post_create_vulkan_setup(vk, info, sc);
|
||||||
|
if (res != XRT_SUCCESS) {
|
||||||
|
vk_ic_destroy(vk, &sc->vkic);
|
||||||
|
free(sc);
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
return XRT_SUCCESS;
|
return XRT_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue