make gryphn create all queue familes

This commit is contained in:
Gregory Wells
2026-05-25 18:03:38 -04:00
parent fb2aa8504f
commit 629036542a
3 changed files with 21 additions and 19 deletions
@@ -1,6 +1,5 @@
#include "gryphn_device.h"
#include "instance/gryphn_instance.h"
#include "stdio.h"
#include "stdlib.h"
gnReturnCode gnCreateDevice(gnInstance instance, gnDeviceCreateInfo* createInfo, gnDevice* device) {
+14 -13
View File
@@ -71,26 +71,22 @@ gnReturnCode vulkanCreateDevice(gnInstance instance, gnDeviceCreateInfo* info, g
}
}
// find queue familes for managment (ive decided that gryphn will manage vulkan queues for you cuz fuck queue manangment)
uint32_t graphicsFamily;
uint32_t queueFamilyCount = 0;
vkGetPhysicalDeviceQueueFamilyProperties(info->physicalDevice->internalData, &queueFamilyCount, NULL);
VkQueueFamilyProperties* queueFamilyProperties = malloc(sizeof(VkQueueFamilyProperties) * queueFamilyCount);
vkGetPhysicalDeviceQueueFamilyProperties(info->physicalDevice->internalData, &queueFamilyCount, queueFamilyProperties);
for (int i = 0; i < queueFamilyCount; i++)
if ((queueFamilyProperties[i].queueFlags & VK_QUEUE_GRAPHICS_BIT) == VK_QUEUE_GRAPHICS_BIT)
graphicsFamily = i;
float queuePriority = 1.0f;
VkDeviceQueueCreateInfo graphicsQueueCreateInfo = {
VkDeviceQueueCreateInfo* queueCreateInfos = malloc(sizeof(VkDeviceQueueCreateInfo) * queueFamilyCount);
for (int i = 0; i < queueFamilyCount; i++) {
queueCreateInfos[i] = (VkDeviceQueueCreateInfo){
.sType = VK_STRUCTURE_TYPE_DEVICE_QUEUE_CREATE_INFO,
.pNext = NULL,
.flags = 0,
.queueFamilyIndex = graphicsFamily,
.queueFamilyIndex = i,
.queueCount = 1,
.pQueuePriorities = &queuePriority
.pQueuePriorities = (float[]){ 1.0f }
};
}
VkPhysicalDeviceFeatures deviceFeatures = {
@@ -100,8 +96,8 @@ gnReturnCode vulkanCreateDevice(gnInstance instance, gnDeviceCreateInfo* info, g
.sType = VK_STRUCTURE_TYPE_DEVICE_CREATE_INFO,
.pNext = NULL,
.flags = 0,
.queueCreateInfoCount = 1,
.pQueueCreateInfos = (VkDeviceQueueCreateInfo[]){ graphicsQueueCreateInfo },
.queueCreateInfoCount = queueFamilyCount,
.pQueueCreateInfos = queueCreateInfos,
.enabledExtensionCount = realEnabledExtensionCount,
.ppEnabledExtensionNames = extensions,
.pEnabledFeatures = &deviceFeatures,
@@ -112,7 +108,12 @@ gnReturnCode vulkanCreateDevice(gnInstance instance, gnDeviceCreateInfo* info, g
device->internalData = malloc(sizeof(vulkanDevice));
((vulkanDevice*)device->internalData)->device = vkDevice;
vkGetDeviceQueue(vkDevice, graphicsFamily, 0, &((vulkanDevice*)device->internalData)->graphicsQueue);
for (int i = 0; i < queueFamilyCount; i++) {
if ((queueFamilyProperties[i].queueFlags & VK_QUEUE_GRAPHICS_BIT) == VK_QUEUE_GRAPHICS_BIT) {
vkGetDeviceQueue(vkDevice, i, 0, &((vulkanDevice*)device->internalData)->graphicsQueue);
break;
}
}
device->dispatchTable.destroyDevice = vulkanDestroyDevice;
free(extensions);
@@ -3,5 +3,7 @@
#include <vulkan/vulkan_core.h>
typedef struct vulkanDevice {
VkDevice device;
uint32_t queueCount;
VkQueue graphicsQueue;
} vulkanDevice;