vulkan: update error db for 0.10.2

This commit is contained in:
Matthew Waters 2015-12-30 14:06:01 +11:00
parent 6fe59754df
commit b38362e75f
5 changed files with 31 additions and 75 deletions

View file

@ -129,8 +129,7 @@ _physical_device_info (GstVulkanDevice * device, GError ** error)
gpu = gst_vulkan_device_get_physical_device (device); gpu = gst_vulkan_device_get_physical_device (device);
if (!gpu) { if (!gpu) {
g_set_error (error, GST_VULKAN_ERROR, g_set_error (error, GST_VULKAN_ERROR, VK_ERROR_INITIALIZATION_FAILED,
GST_VULKAN_ERROR_INITIALIZATION_FAILED,
"Failed to retrieve physical device"); "Failed to retrieve physical device");
return FALSE; return FALSE;
} }
@ -262,8 +261,7 @@ gst_vulkan_device_open (GstVulkanDevice * device, GError ** error)
break; break;
} }
if (i >= device->n_queue_families) { if (i >= device->n_queue_families) {
g_set_error (error, GST_VULKAN_ERROR, g_set_error (error, GST_VULKAN_ERROR, VK_ERROR_INITIALIZATION_FAILED,
GST_VULKAN_ERROR_INITIALIZATION_FAILED,
"Failed to find a compatible queue family"); "Failed to find a compatible queue family");
goto error; goto error;
} }

View file

@ -32,29 +32,21 @@ static const struct
VkResult result; VkResult result;
const char *str; const char *str;
} vk_result_string_map[] = { } vk_result_string_map[] = {
{VK_ERROR_OUT_OF_HOST_MEMORY, "Out Of Host Memory"}, {VK_ERROR_OUT_OF_HOST_MEMORY, "Out Of host memory"},
{VK_ERROR_OUT_OF_DEVICE_MEMORY, "Out of Device Memory"}, {VK_ERROR_OUT_OF_DEVICE_MEMORY, "Out of device memory"},
{VK_ERROR_INITIALIZATION_FAILED, "Initialization Failed"}, {VK_ERROR_INITIALIZATION_FAILED, "Initialization failed"},
{VK_ERROR_DEVICE_LOST, "Device Lost"}, {VK_ERROR_DEVICE_LOST, "Device lost"},
{VK_ERROR_MEMORY_MAP_FAILED, "Map Failed"}, {VK_ERROR_MEMORY_MAP_FAILED, "Map failed"},
{VK_ERROR_LAYER_NOT_PRESENT, "Layer Not Present"}, {VK_ERROR_LAYER_NOT_PRESENT, "Layer not present"},
{VK_ERROR_EXTENSION_NOT_PRESENT, "Extension Not Present"}, {VK_ERROR_EXTENSION_NOT_PRESENT, "Extension not present"},
{VK_ERROR_INCOMPATIBLE_DRIVER, "Incompatible Driver"}, {VK_ERROR_FEATURE_NOT_PRESENT, "Feature not present"},
}; {VK_ERROR_INCOMPATIBLE_DRIVER, "Incompatible driver"},
{VK_ERROR_TOO_MANY_OBJECTS, "Too many objects"},
static const struct {VK_ERROR_FORMAT_NOT_SUPPORTED, "format not supported"},
{ {VK_ERROR_SURFACE_LOST_KHR, "Surface lost"},
VkResult result; {VK_ERROR_OUT_OF_DATE_KHR, "out of date"},
GstVulkanError gst_enum; {VK_ERROR_INCOMPATIBLE_DISPLAY_KHR, "Incompatible display"},
} vk_result_gst_error_map[] = { {VK_ERROR_NATIVE_WINDOW_IN_USE_KHR, "Native window in use"},
{VK_ERROR_OUT_OF_HOST_MEMORY, GST_VULKAN_ERROR_OUT_OF_HOST_MEMORY},
{VK_ERROR_OUT_OF_DEVICE_MEMORY, VK_ERROR_OUT_OF_DEVICE_MEMORY},
{VK_ERROR_INITIALIZATION_FAILED, GST_VULKAN_ERROR_INITIALIZATION_FAILED},
{VK_ERROR_DEVICE_LOST, GST_VULKAN_ERROR_DEVICE_LOST},
{VK_ERROR_MEMORY_MAP_FAILED, GST_VULKAN_ERROR_MEMORY_MAP_FAILED},
{VK_ERROR_LAYER_NOT_PRESENT, GST_VULKAN_ERROR_LAYER_NOT_PRESENT},
{VK_ERROR_EXTENSION_NOT_PRESENT, GST_VULKAN_ERROR_EXTENSION_NOT_PRESENT},
{VK_ERROR_INCOMPATIBLE_DRIVER, GST_VULKAN_ERROR_INCOMPATIBLE_DRIVER},
}; };
/* *INDENT-ON* */ /* *INDENT-ON* */
@ -82,29 +74,10 @@ _vk_result_to_string (VkResult result)
return "Unknown Error"; return "Unknown Error";
} }
static GstVulkanError
_vk_result_to_g_error_enum (VkResult result)
{
int i;
if (result >= 0)
return 0;
if (result < VK_RESULT_BEGIN_RANGE)
return 0;
for (i = 0; i < G_N_ELEMENTS (vk_result_gst_error_map); i++) {
if (result == vk_result_gst_error_map[i].result)
return vk_result_gst_error_map[i].gst_enum;
}
return GST_VULKAN_ERROR_FAILED;
}
VkResult VkResult
gst_vulkan_error_to_g_error (VkResult result, GError ** error, gst_vulkan_error_to_g_error (VkResult result, GError ** error,
const char *format, ...) const char *format, ...)
{ {
GstVulkanError gst_enum;
const char *result_str; const char *result_str;
gchar *string; gchar *string;
va_list args; va_list args;
@ -117,13 +90,11 @@ gst_vulkan_error_to_g_error (VkResult result, GError ** error,
if (result_str == NULL) if (result_str == NULL)
return result; return result;
gst_enum = _vk_result_to_g_error_enum (result);
va_start (args, format); va_start (args, format);
g_vasprintf (&string, format, args); g_vasprintf (&string, format, args);
va_end (args); va_end (args);
g_set_error (error, GST_VULKAN_ERROR, gst_enum, "%s: %s", result_str, string); g_set_error (error, GST_VULKAN_ERROR, result, "%s: %s", result_str, string);
return result; return result;
} }

View file

@ -29,19 +29,6 @@ G_BEGIN_DECLS
#define GST_VULKAN_ERROR (gst_vulkan_error_quark ()) #define GST_VULKAN_ERROR (gst_vulkan_error_quark ())
GQuark gst_vulkan_error_quark (void); GQuark gst_vulkan_error_quark (void);
typedef enum
{
GST_VULKAN_ERROR_FAILED = 0,
GST_VULKAN_ERROR_OUT_OF_HOST_MEMORY = -1,
GST_VULKAN_ERROR_OUT_OF_DEVICE_MEMORY = -2,
GST_VULKAN_ERROR_INITIALIZATION_FAILED = -3,
GST_VULKAN_ERROR_DEVICE_LOST = -4,
GST_VULKAN_ERROR_MEMORY_MAP_FAILED = -5,
GST_VULKAN_ERROR_LAYER_NOT_PRESENT = -6,
GST_VULKAN_ERROR_EXTENSION_NOT_PRESENT = -7,
GST_VULKAN_ERROR_INCOMPATIBLE_DRIVER = -8,
} GstVulkanError;
/* only fills error iff error != NULL and result < 0 */ /* only fills error iff error != NULL and result < 0 */
VkResult gst_vulkan_error_to_g_error (VkResult result, GError ** error, const char * format, ...) G_GNUC_PRINTF (3, 4); VkResult gst_vulkan_error_to_g_error (VkResult result, GError ** error, const char * format, ...) G_GNUC_PRINTF (3, 4);

View file

@ -282,7 +282,7 @@ gst_vulkan_instance_open (GstVulkanInstance * instance, GError ** error)
instance->dbgCreateMsgCallback = (PFN_vkDbgCreateMsgCallback) instance->dbgCreateMsgCallback = (PFN_vkDbgCreateMsgCallback)
gst_vulkan_instance_get_proc_address (instance, "vkDbgCreateMsgCallback"); gst_vulkan_instance_get_proc_address (instance, "vkDbgCreateMsgCallback");
if (!instance->dbgCreateMsgCallback) { if (!instance->dbgCreateMsgCallback) {
g_set_error (error, GST_VULKAN_ERROR, GST_VULKAN_ERROR_FAILED, g_set_error (error, GST_VULKAN_ERROR, VK_ERROR_INITIALIZATION_FAILED,
"Failed to retreive vkDbgCreateMsgCallback"); "Failed to retreive vkDbgCreateMsgCallback");
goto error; goto error;
} }
@ -290,7 +290,7 @@ gst_vulkan_instance_open (GstVulkanInstance * instance, GError ** error)
gst_vulkan_instance_get_proc_address (instance, gst_vulkan_instance_get_proc_address (instance,
"vkDbgDestroyMsgCallback"); "vkDbgDestroyMsgCallback");
if (!instance->dbgDestroyMsgCallback) { if (!instance->dbgDestroyMsgCallback) {
g_set_error (error, GST_VULKAN_ERROR, GST_VULKAN_ERROR_FAILED, g_set_error (error, GST_VULKAN_ERROR, VK_ERROR_INITIALIZATION_FAILED,
"Failed to retreive vkDbgDestroyMsgCallback"); "Failed to retreive vkDbgDestroyMsgCallback");
goto error; goto error;
} }
@ -298,7 +298,7 @@ gst_vulkan_instance_open (GstVulkanInstance * instance, GError ** error)
(PFN_vkDbgMsgCallback) gst_vulkan_instance_get_proc_address (instance, (PFN_vkDbgMsgCallback) gst_vulkan_instance_get_proc_address (instance,
"vkDbgBreakCallback"); "vkDbgBreakCallback");
if (!instance->dbgBreakCallback) { if (!instance->dbgBreakCallback) {
g_set_error (error, GST_VULKAN_ERROR, GST_VULKAN_ERROR_FAILED, g_set_error (error, GST_VULKAN_ERROR, VK_ERROR_INITIALIZATION_FAILED,
"Failed to retreive vkDbgBreakCallback"); "Failed to retreive vkDbgBreakCallback");
goto error; goto error;
} }

View file

@ -199,7 +199,7 @@ _vulkan_swapper_retrieve_surface_properties (GstVulkanSwapper * swapper,
if (graphics_queue != present_queue) { if (graphics_queue != present_queue) {
/* FIXME: add support for separate graphics/present queues */ /* FIXME: add support for separate graphics/present queues */
g_set_error (error, GST_VULKAN_ERROR, g_set_error (error, GST_VULKAN_ERROR,
GST_VULKAN_ERROR_INITIALIZATION_FAILED, VK_ERROR_INITIALIZATION_FAILED,
"Failed to find a compatible present/graphics queue"); "Failed to find a compatible present/graphics queue");
return FALSE; return FALSE;
} }
@ -588,7 +588,7 @@ _allocate_swapchain (GstVulkanSwapper * swapper, GstCaps * caps,
alpha_flags = VK_COMPOSITE_ALPHA_PRE_MULTIPLIED_BIT_KHR; alpha_flags = VK_COMPOSITE_ALPHA_PRE_MULTIPLIED_BIT_KHR;
} else { } else {
g_set_error (error, GST_VULKAN_ERROR, g_set_error (error, GST_VULKAN_ERROR,
GST_VULKAN_ERROR_INITIALIZATION_FAILED, VK_ERROR_INITIALIZATION_FAILED,
"Incorrect alpha flags available for the swap images"); "Incorrect alpha flags available for the swap images");
return FALSE; return FALSE;
} }
@ -601,7 +601,7 @@ _allocate_swapchain (GstVulkanSwapper * swapper, GstCaps * caps,
usage |= VK_IMAGE_USAGE_TRANSFER_DST_BIT; usage |= VK_IMAGE_USAGE_TRANSFER_DST_BIT;
} else { } else {
g_set_error (error, GST_VULKAN_ERROR, g_set_error (error, GST_VULKAN_ERROR,
GST_VULKAN_ERROR_INITIALIZATION_FAILED, VK_ERROR_INITIALIZATION_FAILED,
"Incorrect usage flags available for the swap images"); "Incorrect usage flags available for the swap images");
return FALSE; return FALSE;
} }
@ -611,7 +611,7 @@ _allocate_swapchain (GstVulkanSwapper * swapper, GstCaps * caps,
usage |= VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT; usage |= VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT;
} else { } else {
g_set_error (error, GST_VULKAN_ERROR, g_set_error (error, GST_VULKAN_ERROR,
GST_VULKAN_ERROR_INITIALIZATION_FAILED, VK_ERROR_INITIALIZATION_FAILED,
"Incorrect usage flags available for the swap images"); "Incorrect usage flags available for the swap images");
return FALSE; return FALSE;
} }
@ -714,7 +714,7 @@ gst_vulkan_swapper_set_caps (GstVulkanSwapper * swapper, GstCaps * caps,
{ {
if (!gst_video_info_from_caps (&swapper->v_info, caps)) { if (!gst_video_info_from_caps (&swapper->v_info, caps)) {
g_set_error (error, GST_VULKAN_ERROR, g_set_error (error, GST_VULKAN_ERROR,
GST_VULKAN_ERROR_INITIALIZATION_FAILED, VK_ERROR_INITIALIZATION_FAILED,
"Failed to geto GstVideoInfo from caps"); "Failed to geto GstVideoInfo from caps");
return FALSE; return FALSE;
} }
@ -756,7 +756,7 @@ _build_render_buffer_cmd (GstVulkanSwapper * swapper, guint32 swap_idx,
return FALSE; return FALSE;
if (!gst_video_frame_map (&vframe, &swapper->v_info, buffer, GST_MAP_READ)) { if (!gst_video_frame_map (&vframe, &swapper->v_info, buffer, GST_MAP_READ)) {
g_set_error (error, GST_VULKAN_ERROR, GST_VULKAN_ERROR_MEMORY_MAP_FAILED, g_set_error (error, GST_VULKAN_ERROR, VK_ERROR_MEMORY_MAP_FAILED,
"Failed to map buffer"); "Failed to map buffer");
return FALSE; return FALSE;
} }
@ -768,14 +768,14 @@ _build_render_buffer_cmd (GstVulkanSwapper * swapper, guint32 swap_idx,
VK_IMAGE_USAGE_TRANSFER_SRC_BIT, VK_MEMORY_PROPERTY_HOST_VISIBLE_BIT); VK_IMAGE_USAGE_TRANSFER_SRC_BIT, VK_MEMORY_PROPERTY_HOST_VISIBLE_BIT);
if (!staging) { if (!staging) {
g_set_error (error, GST_VULKAN_ERROR, GST_VULKAN_ERROR_MEMORY_MAP_FAILED, g_set_error (error, GST_VULKAN_ERROR, VK_ERROR_MEMORY_MAP_FAILED,
"Failed to create staging memory"); "Failed to create staging memory");
gst_video_frame_unmap (&vframe); gst_video_frame_unmap (&vframe);
return FALSE; return FALSE;
} }
if (!gst_memory_map ((GstMemory *) staging, &staging_map_info, GST_MAP_WRITE)) { if (!gst_memory_map ((GstMemory *) staging, &staging_map_info, GST_MAP_WRITE)) {
g_set_error (error, GST_VULKAN_ERROR, GST_VULKAN_ERROR_MEMORY_MAP_FAILED, g_set_error (error, GST_VULKAN_ERROR, VK_ERROR_MEMORY_MAP_FAILED,
"Failed to map swap image"); "Failed to map swap image");
gst_video_frame_unmap (&vframe); gst_video_frame_unmap (&vframe);
gst_memory_unref ((GstMemory *) staging); gst_memory_unref ((GstMemory *) staging);
@ -912,12 +912,12 @@ _render_buffer_unlocked (GstVulkanSwapper * swapper,
if (!buffer) { if (!buffer) {
g_set_error (error, GST_VULKAN_ERROR, g_set_error (error, GST_VULKAN_ERROR,
GST_VULKAN_ERROR_INITIALIZATION_FAILED, "Invalid buffer"); VK_ERROR_INITIALIZATION_FAILED, "Invalid buffer");
goto error; goto error;
} }
if (g_atomic_int_get (&swapper->to_quit)) { if (g_atomic_int_get (&swapper->to_quit)) {
g_set_error (error, GST_VULKAN_ERROR, GST_VULKAN_ERROR_DEVICE_LOST, g_set_error (error, GST_VULKAN_ERROR, VK_ERROR_SURFACE_LOST_KHR,
"Output window was closed"); "Output window was closed");
goto error; goto error;
} }