some more vulkan return code production
This commit is contained in:
@@ -18,7 +18,6 @@ gnReturnCode vulkanPhysicalDeviceQueueProperties(gnPhysicalOutputDeviceHandle de
|
|||||||
if ((queueFamilies[i].queueFlags & VK_QUEUE_SPARSE_BINDING_BIT) == VK_QUEUE_SPARSE_BINDING_BIT) queues[i].queueTypeFlags |= GN_QUEUE_SPARSE_BINDING_BIT;
|
if ((queueFamilies[i].queueFlags & VK_QUEUE_SPARSE_BINDING_BIT) == VK_QUEUE_SPARSE_BINDING_BIT) queues[i].queueTypeFlags |= GN_QUEUE_SPARSE_BINDING_BIT;
|
||||||
if ((queueFamilies[i].queueFlags & VK_QUEUE_PROTECTED_BIT) == VK_QUEUE_PROTECTED_BIT) queues[i].queueTypeFlags |= GN_QUEUE_PROTECTED_BIT;
|
if ((queueFamilies[i].queueFlags & VK_QUEUE_PROTECTED_BIT) == VK_QUEUE_PROTECTED_BIT) queues[i].queueTypeFlags |= GN_QUEUE_PROTECTED_BIT;
|
||||||
}
|
}
|
||||||
|
|
||||||
return GN_SUCCESS;
|
return GN_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -20,10 +20,7 @@ gnReturnCode createFramebuffer(gnFramebuffer framebuffer, gnDevice device, gnFra
|
|||||||
.layers = 1
|
.layers = 1
|
||||||
};
|
};
|
||||||
|
|
||||||
if (vkCreateFramebuffer(device->outputDevice->device, &framebufferInfo, NULL, &framebuffer->framebuffer->framebuffer) != VK_SUCCESS) {
|
VkResult res = vkCreateFramebuffer(device->outputDevice->device, &framebufferInfo, NULL, &framebuffer->framebuffer->framebuffer);
|
||||||
return GN_FAILED_TO_CREATE_FRAMEBUFFER;
|
|
||||||
}
|
|
||||||
|
|
||||||
free(attachments);
|
free(attachments);
|
||||||
return GN_SUCCESS;
|
return GN_SUCCESS;
|
||||||
}
|
}
|
||||||
|
@@ -1,10 +1,5 @@
|
|||||||
#include "vulkan_instance.h"
|
#include "vulkan_instance.h"
|
||||||
#include <stdio.h>
|
#include "vulkan_result_converter.h"
|
||||||
|
|
||||||
typedef struct vkUserData {
|
|
||||||
gnDebuggerCallback debuggerCallback;
|
|
||||||
void* userData;
|
|
||||||
} vkUserData;
|
|
||||||
|
|
||||||
static VKAPI_ATTR VkBool32 VKAPI_CALL vk_debuggerDebugCallback(
|
static VKAPI_ATTR VkBool32 VKAPI_CALL vk_debuggerDebugCallback(
|
||||||
VkDebugUtilsMessageSeverityFlagBitsEXT messageSeverity,
|
VkDebugUtilsMessageSeverityFlagBitsEXT messageSeverity,
|
||||||
@@ -40,7 +35,7 @@ static VKAPI_ATTR VkBool32 VKAPI_CALL vk_debuggerDebugCallback(
|
|||||||
return VK_TRUE;
|
return VK_TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
gnReturnCode createInstance(gnInstanceHandle instance, gnInstanceInfo instanceInfo) {
|
gnReturnCode createInstance(gnInstanceHandle instance, gnInstanceCreateInfo* instanceInfo) {
|
||||||
instance->instance = malloc(sizeof(gnPlatformInstance));
|
instance->instance = malloc(sizeof(gnPlatformInstance));
|
||||||
|
|
||||||
vkStringArrayList extensions = vkStringArrayListCreate();
|
vkStringArrayList extensions = vkStringArrayListCreate();
|
||||||
@@ -61,10 +56,10 @@ gnReturnCode createInstance(gnInstanceHandle instance, gnInstanceInfo instanceIn
|
|||||||
|
|
||||||
VkApplicationInfo appInfo = {
|
VkApplicationInfo appInfo = {
|
||||||
.sType = VK_STRUCTURE_TYPE_APPLICATION_INFO,
|
.sType = VK_STRUCTURE_TYPE_APPLICATION_INFO,
|
||||||
.pApplicationName = gnToCString(instanceInfo.applicationName),
|
.pApplicationName = gnToCString(instanceInfo->applicationInfo.applicationName),
|
||||||
.applicationVersion = instanceInfo.applicationVersion,
|
.applicationVersion = instanceInfo->applicationInfo.applicationVersion,
|
||||||
.pEngineName = gnToCString(instanceInfo.engineName),
|
.pEngineName = gnToCString(instanceInfo->applicationInfo.engineName),
|
||||||
.engineVersion = instanceInfo.engineVersion,
|
.engineVersion = instanceInfo->applicationInfo.engineVersion,
|
||||||
.apiVersion = VK_API_VERSION_1_3,
|
.apiVersion = VK_API_VERSION_1_3,
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -78,44 +73,34 @@ gnReturnCode createInstance(gnInstanceHandle instance, gnInstanceInfo instanceIn
|
|||||||
createInfo.flags |= VK_INSTANCE_CREATE_ENUMERATE_PORTABILITY_BIT_KHR;
|
createInfo.flags |= VK_INSTANCE_CREATE_ENUMERATE_PORTABILITY_BIT_KHR;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (instanceInfo.debugger != NULL) {
|
for (int i = 0; i < instanceInfo->debuggerInfo.layerCount; i++) {
|
||||||
for (int i = 0; i < instanceInfo.debugger->layerCount; i++) {
|
if (instanceInfo->debuggerInfo.layers[i] == GN_DEBUGGER_LAYER_PLATFORM) {
|
||||||
if (instanceInfo.debugger->layers[i] == GN_DEBUGGER_LAYER_PLATFORM) {
|
vkStringArrayListAdd(&extensions, VK_EXT_DEBUG_UTILS_EXTENSION_NAME);
|
||||||
vkStringArrayListAdd(&extensions, VK_EXT_DEBUG_UTILS_EXTENSION_NAME);
|
|
||||||
|
|
||||||
const char* validation_layers[1] = { "VK_LAYER_KHRONOS_validation" };
|
const char* validation_layers[1] = { "VK_LAYER_KHRONOS_validation" };
|
||||||
createInfo.enabledLayerCount = 1;
|
createInfo.enabledLayerCount = 1;
|
||||||
createInfo.ppEnabledLayerNames = (const char*[]){ "VK_LAYER_KHRONOS_validation" };
|
createInfo.ppEnabledLayerNames = (const char*[]){ "VK_LAYER_KHRONOS_validation" };
|
||||||
|
|
||||||
vkUserData* userData = malloc(sizeof(vkUserData));
|
instance->instance->userData.debuggerCallback = instanceInfo->debuggerInfo.callback;
|
||||||
userData->debuggerCallback = instanceInfo.debugger->callback;
|
instance->instance->userData.userData = instanceInfo->debuggerInfo.userData;
|
||||||
userData->userData = instanceInfo.debugger->userData;
|
|
||||||
|
|
||||||
VkDebugUtilsMessengerCreateInfoEXT debugCreateInfo = {
|
VkDebugUtilsMessengerCreateInfoEXT debugCreateInfo = {
|
||||||
.sType = VK_STRUCTURE_TYPE_DEBUG_UTILS_MESSENGER_CREATE_INFO_EXT,
|
.sType = VK_STRUCTURE_TYPE_DEBUG_UTILS_MESSENGER_CREATE_INFO_EXT,
|
||||||
.messageSeverity = VK_DEBUG_UTILS_MESSAGE_SEVERITY_VERBOSE_BIT_EXT | VK_DEBUG_UTILS_MESSAGE_SEVERITY_WARNING_BIT_EXT | VK_DEBUG_UTILS_MESSAGE_SEVERITY_ERROR_BIT_EXT,
|
.messageSeverity = VK_DEBUG_UTILS_MESSAGE_SEVERITY_VERBOSE_BIT_EXT | VK_DEBUG_UTILS_MESSAGE_SEVERITY_WARNING_BIT_EXT | VK_DEBUG_UTILS_MESSAGE_SEVERITY_ERROR_BIT_EXT,
|
||||||
.messageType = VK_DEBUG_UTILS_MESSAGE_TYPE_GENERAL_BIT_EXT | VK_DEBUG_UTILS_MESSAGE_TYPE_VALIDATION_BIT_EXT | VK_DEBUG_UTILS_MESSAGE_TYPE_PERFORMANCE_BIT_EXT
|
.messageType = VK_DEBUG_UTILS_MESSAGE_TYPE_GENERAL_BIT_EXT | VK_DEBUG_UTILS_MESSAGE_TYPE_VALIDATION_BIT_EXT | VK_DEBUG_UTILS_MESSAGE_TYPE_PERFORMANCE_BIT_EXT
|
||||||
};
|
};
|
||||||
debugCreateInfo.pfnUserCallback = vk_debuggerDebugCallback;
|
debugCreateInfo.pfnUserCallback = vk_debuggerDebugCallback;
|
||||||
debugCreateInfo.pUserData = userData;
|
debugCreateInfo.pUserData = &instance->instance->userData;
|
||||||
createInfo.pNext = &debugCreateInfo;
|
createInfo.pNext = &debugCreateInfo;
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
createInfo.enabledExtensionCount = extensions.count;
|
createInfo.enabledExtensionCount = extensions.count;
|
||||||
createInfo.ppEnabledExtensionNames = extensions.data;
|
createInfo.ppEnabledExtensionNames = extensions.data;
|
||||||
|
return VkResultToGnReturnCode(vkCreateInstance(&createInfo, NULL, &instance->instance->vk_instance));
|
||||||
VkResult result = vkCreateInstance(&createInfo, NULL, &instance->instance->vk_instance);
|
|
||||||
if (result != VK_SUCCESS)
|
|
||||||
return GN_FAILED_CREATE_INSTANCE;
|
|
||||||
instance->valid = GN_TRUE;
|
|
||||||
|
|
||||||
return GN_SUCCESS;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void destroyInstance(gnInstanceHandle instance) {
|
void destroyInstance(gnInstanceHandle instance) {
|
||||||
instance->valid = GN_FALSE;
|
|
||||||
vkDestroyInstance(instance->instance->vk_instance, NULL);
|
vkDestroyInstance(instance->instance->vk_instance, NULL);
|
||||||
}
|
}
|
||||||
|
@@ -3,12 +3,17 @@
|
|||||||
#include "instance/gryphn_instance.h"
|
#include "instance/gryphn_instance.h"
|
||||||
#include "utils/lists/gryphn_array_list.h"
|
#include "utils/lists/gryphn_array_list.h"
|
||||||
|
|
||||||
|
typedef struct vkUserData {
|
||||||
|
gnDebuggerCallback debuggerCallback;
|
||||||
|
void* userData;
|
||||||
|
} vkUserData;
|
||||||
|
|
||||||
typedef struct gnPlatformInstance_t {
|
typedef struct gnPlatformInstance_t {
|
||||||
VkInstance vk_instance;
|
VkInstance vk_instance;
|
||||||
VkApplicationInfo appInfo;
|
vkUserData userData;
|
||||||
} gnPlatformInstance;
|
} gnPlatformInstance;
|
||||||
|
|
||||||
gnReturnCode createInstance(gnInstanceHandle instance, gnInstanceInfo instanceInfo);
|
gnReturnCode createInstance(gnInstanceHandle instance, gnInstanceCreateInfo* instanceInfo);
|
||||||
void destroyInstance(gnInstanceHandle instance);
|
void destroyInstance(gnInstanceHandle instance);
|
||||||
|
|
||||||
typedef const char* vkString;
|
typedef const char* vkString;
|
||||||
|
@@ -4,6 +4,7 @@
|
|||||||
#include "vulkan_device_extensions.h"
|
#include "vulkan_device_extensions.h"
|
||||||
#include "instance/gryphn_instance.h"
|
#include "instance/gryphn_instance.h"
|
||||||
#include "commands/command_buffer/vulkan_command_buffer.h"
|
#include "commands/command_buffer/vulkan_command_buffer.h"
|
||||||
|
#include "vulkan_result_converter.h"
|
||||||
|
|
||||||
gnReturnCode createOutputDevice(gnOutputDeviceHandle outputDevice, gnInstanceHandle instance, gnOutputDeviceInfo deviceInfo) {
|
gnReturnCode createOutputDevice(gnOutputDeviceHandle outputDevice, gnInstanceHandle instance, gnOutputDeviceInfo deviceInfo) {
|
||||||
outputDevice->outputDevice = malloc(sizeof(gnPlatformOutputDevice));
|
outputDevice->outputDevice = malloc(sizeof(gnPlatformOutputDevice));
|
||||||
@@ -58,8 +59,9 @@ gnReturnCode createOutputDevice(gnOutputDeviceHandle outputDevice, gnInstanceHan
|
|||||||
deviceCreateInfo.ppEnabledLayerNames = validation_layers;
|
deviceCreateInfo.ppEnabledLayerNames = validation_layers;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (vkCreateDevice(deviceInfo.physicalDevice->physicalDevice->device, &deviceCreateInfo, NULL, &outputDevice->outputDevice->device) != VK_SUCCESS)
|
VkResult result = vkCreateDevice(deviceInfo.physicalDevice->physicalDevice->device, &deviceCreateInfo, NULL, &outputDevice->outputDevice->device);
|
||||||
return GN_FAILED_TO_CREATE_DEVICE;
|
if (result != VK_SUCCESS)
|
||||||
|
return VkResultToGnReturnCode(result);
|
||||||
|
|
||||||
outputDevice->outputDevice->queues = malloc(sizeof(vulkanQueue) * deviceInfo.physicalDevice->physicalDevice->neededQueueCount);
|
outputDevice->outputDevice->queues = malloc(sizeof(vulkanQueue) * deviceInfo.physicalDevice->physicalDevice->neededQueueCount);
|
||||||
uint32_t transferQueue = 0;
|
uint32_t transferQueue = 0;
|
||||||
@@ -83,11 +85,13 @@ gnReturnCode createOutputDevice(gnOutputDeviceHandle outputDevice, gnInstanceHan
|
|||||||
.queueFamilyIndex = transferQueue
|
.queueFamilyIndex = transferQueue
|
||||||
};
|
};
|
||||||
|
|
||||||
if (vkCreateCommandPool(outputDevice->outputDevice->device, &poolInfo, NULL, &outputDevice->outputDevice->transferCommandPool) != VK_SUCCESS)
|
VkResult command_pool_result = vkCreateCommandPool(outputDevice->outputDevice->device, &poolInfo, NULL, &outputDevice->outputDevice->transferCommandPool);
|
||||||
return GN_FAILED_TO_CREATE_COMMAND_POOL;
|
if (command_pool_result != VK_SUCCESS)
|
||||||
|
return VkResultToGnReturnCode(command_pool_result);
|
||||||
|
|
||||||
VkFenceCreateInfo fenceInfo = { .sType = VK_STRUCTURE_TYPE_FENCE_CREATE_INFO };
|
VkFenceCreateInfo fenceInfo = { .sType = VK_STRUCTURE_TYPE_FENCE_CREATE_INFO };
|
||||||
if (vkCreateFence(outputDevice->outputDevice->device, &fenceInfo, NULL, &outputDevice->outputDevice->barrierFence) != VK_SUCCESS) return GN_FAILED_TO_CREATE_FENCE;
|
VkResult fence_result = vkCreateFence(outputDevice->outputDevice->device, &fenceInfo, NULL, &outputDevice->outputDevice->barrierFence);
|
||||||
|
if (fence_result != VK_SUCCESS) VkResultToGnReturnCode(fence_result);
|
||||||
|
|
||||||
// create the massive staging buffer
|
// create the massive staging buffer
|
||||||
outputDevice->outputDevice->stagingBufferSize = 128 * 1024 * 1024;
|
outputDevice->outputDevice->stagingBufferSize = 128 * 1024 * 1024;
|
||||||
|
@@ -1,5 +1,5 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
#include "utils/gryphn_error_code.h"
|
#include "core/gryphn_return_code.h"
|
||||||
#include "gryphn_handles.h"
|
#include "gryphn_handles.h"
|
||||||
|
|
||||||
typedef enum gnQueueTypeBits {
|
typedef enum gnQueueTypeBits {
|
||||||
|
Reference in New Issue
Block a user