device queue create infos
This commit is contained in:
@@ -8,15 +8,31 @@
|
||||
gnReturnCode createOutputDevice(gnOutputDeviceHandle outputDevice, gnInstanceHandle instance, gnOutputDeviceInfo deviceInfo) {
|
||||
outputDevice->outputDevice = malloc(sizeof(gnPlatformOutputDevice));
|
||||
|
||||
VkDeviceQueueCreateInfo* queueCreateInfos = malloc(sizeof(VkDeviceQueueCreateInfo) * deviceInfo.physicalDevice->physicalDevice->neededQueueCount);
|
||||
int createQueueCount = 0;
|
||||
VkDeviceQueueCreateInfo* queueCreateInfos = NULL;
|
||||
|
||||
if (!instance->enabledExtensions[GN_EXT_QUEUES]) {
|
||||
queueCreateInfos = malloc(sizeof(VkDeviceQueueCreateInfo) * deviceInfo.physicalDevice->physicalDevice->neededQueueCount);
|
||||
createQueueCount = deviceInfo.physicalDevice->physicalDevice->neededQueueCount;
|
||||
float queuePriority = 1.0f;
|
||||
for (int i = 0; i < deviceInfo.physicalDevice->physicalDevice->neededQueueCount; i++) {
|
||||
queueCreateInfos[i].sType = VK_STRUCTURE_TYPE_DEVICE_QUEUE_CREATE_INFO;
|
||||
queueCreateInfos[i].flags = 0;
|
||||
queueCreateInfos[i].queueFamilyIndex = deviceInfo.physicalDevice->physicalDevice->neededQueues[i].queueIndex;
|
||||
queueCreateInfos[i].queueCount = 1;
|
||||
queueCreateInfos[i].queueFamilyIndex = deviceInfo.physicalDevice->physicalDevice->neededQueues[i].queueIndex;
|
||||
queueCreateInfos[i].pQueuePriorities = &queuePriority;
|
||||
}
|
||||
} else {
|
||||
createQueueCount = deviceInfo.queueInfoCount;
|
||||
queueCreateInfos = malloc(sizeof(VkDeviceQueueCreateInfo) * deviceInfo.queueInfoCount);
|
||||
for (int i = 0; i < deviceInfo.queueInfoCount; i++) {
|
||||
queueCreateInfos[i].sType = VK_STRUCTURE_TYPE_DEVICE_QUEUE_CREATE_INFO;
|
||||
queueCreateInfos[i].flags = 0;
|
||||
queueCreateInfos[i].queueCount = deviceInfo.queueInfos[i].queueCount;
|
||||
queueCreateInfos[i].queueFamilyIndex = deviceInfo.queueInfos[i].queueFamilyIndex;
|
||||
queueCreateInfos[i].pQueuePriorities = deviceInfo.queueInfos[i].queuePrioritys;
|
||||
}
|
||||
}
|
||||
|
||||
VkPhysicalDeviceFeatures deviceFeatures = {
|
||||
.samplerAnisotropy = VK_TRUE
|
||||
@@ -24,7 +40,7 @@ gnReturnCode createOutputDevice(gnOutputDeviceHandle outputDevice, gnInstanceHan
|
||||
|
||||
VkDeviceCreateInfo deviceCreateInfo = {
|
||||
.sType = VK_STRUCTURE_TYPE_DEVICE_CREATE_INFO,
|
||||
.queueCreateInfoCount = deviceInfo.physicalDevice->physicalDevice->neededQueueCount,
|
||||
.queueCreateInfoCount = createQueueCount,
|
||||
.pQueueCreateInfos = queueCreateInfos,
|
||||
.pEnabledFeatures = &deviceFeatures
|
||||
};
|
||||
|
@@ -2,19 +2,20 @@
|
||||
#include <output_device/gryphn_physical_output_device.h>
|
||||
#include <utils/gryphn_error_code.h>
|
||||
|
||||
// typedef struct gnDeviceQueueInfo {
|
||||
// int queueIndex;
|
||||
// int queueCount;
|
||||
// // float* queuePriority;
|
||||
// } gnDeviceQueueInfo;
|
||||
|
||||
typedef struct gnOutputDeviceEnabledFeatures {
|
||||
|
||||
} gnOutputDeviceEnabledFeatures;
|
||||
|
||||
typedef struct gnDeviceQueueInfo {
|
||||
int queueFamilyIndex;
|
||||
int queueCount;
|
||||
float* queuePrioritys;
|
||||
} gnDeviceQueueInfo;
|
||||
|
||||
typedef struct gnOutputDeviceInfo {
|
||||
// uint32_t queueInfoCount;
|
||||
// gnDeviceQueueInfo* queueInfos;
|
||||
uint32_t queueInfoCount;
|
||||
gnDeviceQueueInfo* queueInfos; // only used if GN_EXT_QUEUES is enabled
|
||||
|
||||
gnOutputDeviceEnabledFeatures enabledFeatures;
|
||||
gnPhysicalDevice physicalDevice;
|
||||
} gnOutputDeviceInfo;
|
||||
|
Reference in New Issue
Block a user