Я пытаюсь написать разделяемую библиотеку (в c), которая должна инициировать vulkan (среди прочего).Под инициацией я подразумеваю, что он должен выполнить всю цепочку установки, начиная от создания экземпляра до создания конвейера.
Когда я вызываю вышеупомянутую функцию как статическую библиотечную функцию -> все работает, и в vkCreateGraphicsPipelines не возникает segfault.Однако, когда я создаю ту же функцию, что и разделяемая (.so) библиотека, и вызываю ее -> vkCreateGraphicsPipelines's segfault.
Обновление 07.03.19
Слои проверки теперь работают на полную мощность.
Компиляция со статической библиотекой:
gcc test.c -lvulkan -lglfw -lvui_static
Вывод обратного вызова относительно создания конвейера (функция обычно завершается):
creating pipeline!
Thread 0, Frame 0:
vkCreateGraphicsPipelines(device, pipelineCache, createInfoCount, pCreateInfos, pAllocator, pPipelines) returns VkResult VK_SUCCESS (0):
device: VkDevice = 0x559b52daf3a0
pipelineCache: VkPipelineCache = 0
createInfoCount: uint32_t = 1
pCreateInfos: const VkGraphicsPipelineCreateInfo* = 0x559b52cd57f8
pCreateInfos[0]: const VkGraphicsPipelineCreateInfo = 0x559b52cd57f8:
sType: VkStructureType = VK_STRUCTURE_TYPE_GRAPHICS_PIPELINE_CREATE_INFO (28)
pNext: const void* = NULL
flags: VkPipelineCreateFlags = 0
stageCount: uint32_t = 2
pStages: const VkPipelineShaderStageCreateInfo* = 0x559b52cd8058
pStages[0]: const VkPipelineShaderStageCreateInfo = 0x559b52cd8058:
sType: VkStructureType = VK_STRUCTURE_TYPE_PIPELINE_SHADER_STAGE_CREATE_INFO (18)
pNext: const void* = NULL
flags: VkPipelineShaderStageCreateFlags = 0
stage: VkShaderStageFlagBits = 1 (VK_SHADER_STAGE_VERTEX_BIT | VK_SHADER_STAGE_ALL_GRAPHICS | VK_SHADER_STAGE_ALL)
module: VkShaderModule = 0x559b52cd8910
pName: const char* = "main"
pSpecializationInfo: const VkSpecializationInfo* = NULL
pStages[1]: const VkPipelineShaderStageCreateInfo = 0x559b52cd8088:
sType: VkStructureType = VK_STRUCTURE_TYPE_PIPELINE_SHADER_STAGE_CREATE_INFO (18)
pNext: const void* = NULL
flags: VkPipelineShaderStageCreateFlags = 0
stage: VkShaderStageFlagBits = 16 (VK_SHADER_STAGE_FRAGMENT_BIT | VK_SHADER_STAGE_ALL_GRAPHICS | VK_SHADER_STAGE_ALL)
module: VkShaderModule = 0x559b52dcc6b0
pName: const char* = "main"
pSpecializationInfo: const VkSpecializationInfo* = NULL
pVertexInputState: const VkPipelineVertexInputStateCreateInfo* = 0x559b52dcf790:
sType: VkStructureType = VK_STRUCTURE_TYPE_PIPELINE_VERTEX_INPUT_STATE_CREATE_INFO (19)
pNext: const void* = NULL
flags: VkPipelineVertexInputStateCreateFlags = 0
vertexBindingDescriptionCount: uint32_t = 0
pVertexBindingDescriptions: const VkVertexInputBindingDescription* = NULL
vertexAttributeDescriptionCount: uint32_t = 0
pVertexAttributeDescriptions: const VkVertexInputAttributeDescription* = NULL
pInputAssemblyState: const VkPipelineInputAssemblyStateCreateInfo* = 0x559b52dcf030:
sType: VkStructureType = VK_STRUCTURE_TYPE_PIPELINE_INPUT_ASSEMBLY_STATE_CREATE_INFO (20)
pNext: const void* = NULL
flags: VkPipelineInputAssemblyStateCreateFlags = 0
topology: VkPrimitiveTopology = VK_PRIMITIVE_TOPOLOGY_TRIANGLE_LIST (3)
primitiveRestartEnable: VkBool32 = 0
pTessellationState: const VkPipelineTessellationStateCreateInfo* = NULL
pViewportState: const VkPipelineViewportStateCreateInfo* = 0x559b52dcf140:
sType: VkStructureType = VK_STRUCTURE_TYPE_PIPELINE_VIEWPORT_STATE_CREATE_INFO (22)
pNext: const void* = NULL
flags: VkPipelineViewportStateCreateFlags = 0
viewportCount: uint32_t = 1
pViewports: const VkViewport* = 0x559b52dc8e70
pViewports[0]: const VkViewport = 0x559b52dc8e70:
x: float = 0
y: float = 0
width: float = 500
height: float = 500
minDepth: float = 0
maxDepth: float = 1
scissorCount: uint32_t = 1
pScissors: const VkRect2D* = 0x559b52dc94f0
pScissors[0]: const VkRect2D = 0x559b52dc94f0:
offset: VkOffset2D = 0x559b52dc94f0:
x: int32_t = 0
y: int32_t = 0
extent: VkExtent2D = 0x559b52dc94f8:
width: uint32_t = 500
height: uint32_t = 500
pRasterizationState: const VkPipelineRasterizationStateCreateInfo* = 0x559b52dca7a0:
sType: VkStructureType = VK_STRUCTURE_TYPE_PIPELINE_RASTERIZATION_STATE_CREATE_INFO (23)
pNext: const void* = NULL
flags: VkPipelineRasterizationStateCreateFlags = 0
depthClampEnable: VkBool32 = 0
rasterizerDiscardEnable: VkBool32 = 0
polygonMode: VkPolygonMode = VK_POLYGON_MODE_FILL (0)
cullMode: VkCullModeFlags = 2 (VK_CULL_MODE_BACK_BIT | VK_CULL_MODE_FRONT_AND_BACK)
frontFace: VkFrontFace = VK_FRONT_FACE_CLOCKWISE (1)
depthBiasEnable: VkBool32 = 0
depthBiasConstantFactor: float = 0
depthBiasClamp: float = 0
depthBiasSlopeFactor: float = 0
lineWidth: float = 1
pMultisampleState: const VkPipelineMultisampleStateCreateInfo* = 0x559b52dc93e0:
sType: VkStructureType = VK_STRUCTURE_TYPE_PIPELINE_MULTISAMPLE_STATE_CREATE_INFO (24)
pNext: const void* = NULL
flags: VkPipelineMultisampleStateCreateFlags = 0
rasterizationSamples: VkSampleCountFlagBits = 1 (VK_SAMPLE_COUNT_1_BIT)
sampleShadingEnable: VkBool32 = 0
minSampleShading: float = 0
pSampleMask: const VkSampleMask* = NULL
alphaToCoverageEnable: VkBool32 = 0
alphaToOneEnable: VkBool32 = 0
pDepthStencilState: const VkPipelineDepthStencilStateCreateInfo* = NULL
pColorBlendState: const VkPipelineColorBlendStateCreateInfo* = 0x559b52cd6f90:
sType: VkStructureType = VK_STRUCTURE_TYPE_PIPELINE_COLOR_BLEND_STATE_CREATE_INFO (26)
pNext: const void* = NULL
flags: VkPipelineColorBlendStateCreateFlags = 0
logicOpEnable: VkBool32 = 0
logicOp: VkLogicOp = VK_LOGIC_OP_COPY (3)
attachmentCount: uint32_t = 1
pAttachments: const VkPipelineColorBlendAttachmentState* = 0x559b52dcf0a0
pAttachments[0]: const VkPipelineColorBlendAttachmentState = 0x559b52dcf0a0:
blendEnable: VkBool32 = 0
srcColorBlendFactor: VkBlendFactor = VK_BLEND_FACTOR_ZERO (0)
dstColorBlendFactor: VkBlendFactor = VK_BLEND_FACTOR_ZERO (0)
colorBlendOp: VkBlendOp = VK_BLEND_OP_ADD (0)
srcAlphaBlendFactor: VkBlendFactor = VK_BLEND_FACTOR_ZERO (0)
dstAlphaBlendFactor: VkBlendFactor = VK_BLEND_FACTOR_ZERO (0)
alphaBlendOp: VkBlendOp = VK_BLEND_OP_ADD (0)
colorWriteMask: VkColorComponentFlags = 15 (VK_COLOR_COMPONENT_R_BIT | VK_COLOR_COMPONENT_G_BIT | VK_COLOR_COMPONENT_B_BIT | VK_COLOR_COMPONENT_A_BIT)
blendConstants: float[4] = 0x559b52cd6fb8
blendConstants[0]: float = 0
blendConstants[1]: float = 0
blendConstants[2]: float = 0
blendConstants[3]: float = 0
pDynamicState: const VkPipelineDynamicStateCreateInfo* = NULL
layout: VkPipelineLayout = 0x559b52cd6de0
renderPass: VkRenderPass = 0x559b52c582d0
subpass: uint32_t = 0
basePipelineHandle: VkPipeline = 0
basePipelineIndex: int32_t = 0
pAllocator: const VkAllocationCallbacks* = NULL
pPipelines: VkPipeline* = 0x559b528e53e0
pPipelines[0]: VkPipeline = 0x559b52dcaa60
pipeline created!
Компиляция с общей библиотекой:
gcc test.c -lvulkan -lglfw -lvui
Вывод обратного вызова, касающийся создания конвейера (функция завершается ненормально -> нет дампа API):
creating pipeline!
Segmentation fault (core dumped)
Обратный путь GDB:
Thread 1 "a.out" received signal SIGSEGV, Segmentation fault.
0x00007ffff7d1549a in crc32 () from /usr/local/lib/libvui.so.0
(gdb) bt
#0 0x00007ffff7d1549a in crc32 () from /usr/local/lib/libvui.so.0
#1 0x00007ffff5fb252f in ?? () from /usr/lib/libvulkan_intel.so
#2 0x00007ffff5fac515 in ?? () from /usr/lib/libvulkan_intel.so
#3 0x00007ffff5e42d13 in ?? () from /usr/lib/libvulkan_intel.so
#4 0x00007ffff5e403d3 in ?? () from /usr/lib/libvulkan_intel.so
#5 0x00007ffff5e41bbb in ?? () from /usr/lib/libvulkan_intel.so
#6 0x00007ffff5e6ce44 in ?? () from /usr/lib/libvulkan_intel.so
#7 0x00007ffff5454aff in vkCreateGraphicsPipelines ()
vui_vulkanInit.c (вызывает vkCreateGraphicsPipeline ()):
#include "../vui_vulkanInit.h"
#include "../vui_debug.h"
#include <GLFW/glfw3.h>
#include <vulkan/vulkan.h>
#include <stdint.h>
#include <limits.h>
#include <string.h>
#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
void initVulkan()
{
// handles
GLFWwindow* window;
VkInstance *instance = malloc(sizeof(VkInstance));
VkSurfaceKHR *surface = malloc(sizeof(VkSurfaceKHR));
VkPhysicalDevice *physicalDevice = malloc(sizeof(VkPhysicalDevice));
VkDevice *device = malloc(sizeof(VkDevice));
VkQueue *graphicsQueue = malloc(sizeof(VkQueue));
VkSwapchainKHR *swapChain = malloc(sizeof(VkSwapchainKHR));
VkImage *swapChainImages = malloc(sizeof(VkImage) * 3);
VkFormat *swapChainImageFormat = malloc(sizeof(VkFormat));
VkExtent2D *swapChainExtent = malloc(sizeof(VkExtent2D));
VkImageView *swapChainImageViews = malloc(sizeof(VkImageView) * 3);
VkRenderPass *renderPass = malloc(sizeof(VkRenderPass));
VkPipelineLayout *pipelineLayout = malloc(sizeof(VkPipelineLayout));
VkPipeline *graphicsPipeline = malloc(sizeof(VkPipeline));
VkDebugUtilsMessengerEXT *callback = malloc(sizeof(VkDebugUtilsMessengerEXT));
if (errno == ENOMEM)
exit(EXIT_FAILURE);
// glfw window
glfwInit();
glfwWindowHint(GLFW_CLIENT_API, GLFW_NO_API);
glfwWindowHint(GLFW_RESIZABLE, GLFW_FALSE);
window = glfwCreateWindow(500, 500, "Vulkan", VK_NULL_HANDLE, VK_NULL_HANDLE);
if (!window)
exit(EXIT_FAILURE);
// instance
VkApplicationInfo appInfo = {};
appInfo.sType = VK_STRUCTURE_TYPE_APPLICATION_INFO;
appInfo.pApplicationName = "Hello Triangle";
appInfo.applicationVersion = VK_MAKE_VERSION(1, 0, 0);
appInfo.pEngineName = "No Engine";
appInfo.engineVersion = VK_MAKE_VERSION(1, 0, 0);
appInfo.apiVersion = VK_API_VERSION_1_1;
VkInstanceCreateInfo instanceInfo = {};
instanceInfo.sType = VK_STRUCTURE_TYPE_INSTANCE_CREATE_INFO;
instanceInfo.pApplicationInfo = &appInfo;
// validation layers
const char *validationLayers[2] = {"VK_LAYER_LUNARG_standard_validation", "VK_LAYER_LUNARG_api_dump"};
instanceInfo.enabledLayerCount = 2;
instanceInfo.ppEnabledLayerNames = validationLayers;
// extensions
char *ext1_p = VK_EXT_DEBUG_UTILS_EXTENSION_NAME;
uint32_t glfwExtensionCount = 0;
glfwGetRequiredInstanceExtensions(&glfwExtensionCount);
uint32_t totalExtensionCount = glfwExtensionCount + 1;
const char **glfwExtensions = glfwGetRequiredInstanceExtensions(&glfwExtensionCount);
const char *extensions[totalExtensionCount];
extensions[0] = ext1_p;
for (int i = 1; i < glfwExtensionCount + 1; ++i)
extensions[i] = glfwExtensions[i - 1];
instanceInfo.enabledExtensionCount = totalExtensionCount;
instanceInfo.ppEnabledExtensionNames = extensions;
VK_ASSERT(vkCreateInstance(&instanceInfo, VK_NULL_HANDLE, instance));
// validation callback
vui_createVulkanMessenger(*instance, callback);
// surface
VK_ASSERT(glfwCreateWindowSurface(*instance, window, VK_NULL_HANDLE, surface));
// physical device
uint32_t deviceCount = 0;
vkEnumeratePhysicalDevices(*instance, &deviceCount, VK_NULL_HANDLE);
VkPhysicalDevice devices[deviceCount];
vkEnumeratePhysicalDevices(*instance, &deviceCount, devices);
// there is only one device possible because I have no dedicated gpu
for (int i = 0; i < deviceCount; ++i) {
physicalDevice = &(devices[i]);
break;
}
// device
uint32_t queueFamilyIndex = 0;
float queuePriority = 1.0f;
VkDeviceQueueCreateInfo queueCreateInfo = {};
queueCreateInfo.sType = VK_STRUCTURE_TYPE_DEVICE_QUEUE_CREATE_INFO;
queueCreateInfo.queueFamilyIndex = queueFamilyIndex;
queueCreateInfo.queueCount = 1;
queueCreateInfo.pQueuePriorities = &queuePriority;
VkPhysicalDeviceFeatures deviceFeatures = {};
const char *deviceExtensions = VK_KHR_SWAPCHAIN_EXTENSION_NAME;
VkDeviceCreateInfo deviceInfo = {};
deviceInfo.sType = VK_STRUCTURE_TYPE_DEVICE_CREATE_INFO;
deviceInfo.queueCreateInfoCount = 1;
deviceInfo.pQueueCreateInfos = &queueCreateInfo;
deviceInfo.pEnabledFeatures = &deviceFeatures;
deviceInfo.enabledExtensionCount = 1;
deviceInfo.ppEnabledExtensionNames = &deviceExtensions;
deviceInfo.enabledLayerCount = 0;
VK_ASSERT(vkCreateDevice(*physicalDevice, &deviceInfo, VK_NULL_HANDLE, device));
vkGetDeviceQueue(*device, queueFamilyIndex, 0, graphicsQueue);
// swapchain
VkSurfaceCapabilitiesKHR capabilities;
vkGetPhysicalDeviceSurfaceCapabilitiesKHR(*physicalDevice, *surface, &capabilities);
uint32_t formatCount;
vkGetPhysicalDeviceSurfaceFormatsKHR(*physicalDevice, *surface, &formatCount, VK_NULL_HANDLE);
VkSurfaceFormatKHR formats[formatCount];
if (formatCount != 0)
vkGetPhysicalDeviceSurfaceFormatsKHR(*physicalDevice, *surface, &formatCount, formats);
// these assumptions are fine for the purpose of debugging
VkSurfaceFormatKHR surfaceFormat = formats[1];
VkPresentModeKHR presentMode = VK_PRESENT_MODE_IMMEDIATE_KHR;
VkExtent2D extent = capabilities.currentExtent;
uint32_t imageCount = 3;
VkSwapchainCreateInfoKHR swapchainInfo = {};
swapchainInfo.sType = VK_STRUCTURE_TYPE_SWAPCHAIN_CREATE_INFO_KHR;
swapchainInfo.surface = *surface;
swapchainInfo.minImageCount = imageCount;
swapchainInfo.imageFormat = surfaceFormat.format;
swapchainInfo.imageColorSpace = surfaceFormat.colorSpace;
swapchainInfo.imageExtent = extent;
swapchainInfo.imageArrayLayers = 1;
swapchainInfo.imageUsage = VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT;
swapchainInfo.imageSharingMode = VK_SHARING_MODE_EXCLUSIVE;
swapchainInfo.queueFamilyIndexCount = 1;
swapchainInfo.pQueueFamilyIndices = &queueFamilyIndex;
swapchainInfo.preTransform = capabilities.currentTransform;
swapchainInfo.compositeAlpha = VK_COMPOSITE_ALPHA_OPAQUE_BIT_KHR;
swapchainInfo.presentMode = presentMode;
swapchainInfo.clipped = VK_TRUE;
swapchainInfo.oldSwapchain = VK_NULL_HANDLE;
VK_ASSERT(vkCreateSwapchainKHR(*device, &swapchainInfo, VK_NULL_HANDLE, swapChain));
vkGetSwapchainImagesKHR(*device, *swapChain, &imageCount, VK_NULL_HANDLE);
vkGetSwapchainImagesKHR(*device, *swapChain, &imageCount, swapChainImages);
*swapChainImageFormat = surfaceFormat.format;
*swapChainExtent = extent;
// render pass
// ! Please note: structs abstracted.
VK_ASSERT(vkCreateRenderPass(*device, &renderPassInfo, VK_NULL_HANDLE, renderPass));
// pipeline layout
VkPipelineLayoutCreateInfo pipelineLayoutInfo = {};
pipelineLayoutInfo.sType = VK_STRUCTURE_TYPE_PIPELINE_LAYOUT_CREATE_INFO;
pipelineLayoutInfo.setLayoutCount = 0;
pipelineLayoutInfo.pushConstantRangeCount = 0;
VK_ASSERT(vkCreatePipelineLayout(*device, &pipelineLayoutInfo, VK_NULL_HANDLE, pipelineLayout));
// pipeline
const uint32_t vs_code[] =
{
#include "absPath"
};
VkShaderModule vertShaderModule = createShaderModule(*device, vs_code, sizeof(vs_code));
const uint32_t fs_code[] =
{
#include "absPath"
};
VkShaderModule fragShaderModule = createShaderModule(*device, fs_code, sizeof(fs_code));
VkPipelineShaderStageCreateInfo vertShaderStageInfo = {};
vertShaderStageInfo.sType = VK_STRUCTURE_TYPE_PIPELINE_SHADER_STAGE_CREATE_INFO;
vertShaderStageInfo.stage = VK_SHADER_STAGE_VERTEX_BIT;
vertShaderStageInfo.module = vertShaderModule;
vertShaderStageInfo.pName = "main";
VkPipelineShaderStageCreateInfo fragShaderStageInfo = {};
fragShaderStageInfo.sType = VK_STRUCTURE_TYPE_PIPELINE_SHADER_STAGE_CREATE_INFO;
fragShaderStageInfo.stage = VK_SHADER_STAGE_FRAGMENT_BIT;
fragShaderStageInfo.module = fragShaderModule;
fragShaderStageInfo.pName = "main";
VkPipelineShaderStageCreateInfo shaderStages[] = {vertShaderStageInfo, fragShaderStageInfo};
VkPipelineVertexInputStateCreateInfo vertexInputInfo = {};
vertexInputInfo.sType = VK_STRUCTURE_TYPE_PIPELINE_VERTEX_INPUT_STATE_CREATE_INFO;
vertexInputInfo.vertexBindingDescriptionCount = 0;
vertexInputInfo.vertexAttributeDescriptionCount = 0;
VkPipelineInputAssemblyStateCreateInfo inputAssembly = {};
inputAssembly.sType = VK_STRUCTURE_TYPE_PIPELINE_INPUT_ASSEMBLY_STATE_CREATE_INFO;
inputAssembly.topology = VK_PRIMITIVE_TOPOLOGY_TRIANGLE_LIST;
inputAssembly.primitiveRestartEnable = VK_FALSE;
VkViewport viewport = {};
viewport.x = 0.0f;
viewport.y = 0.0f;
viewport.width = (float) (*swapChainExtent).width;
viewport.height = (float) (*swapChainExtent).height;
viewport.minDepth = 0.0f;
viewport.maxDepth = 1.0f;
VkOffset2D offset;
offset.x = 0;
offset.y = 0;
VkRect2D scissor = {};
scissor.offset = offset;
scissor.extent = *swapChainExtent;
VkPipelineViewportStateCreateInfo viewportState = {};
viewportState.sType = VK_STRUCTURE_TYPE_PIPELINE_VIEWPORT_STATE_CREATE_INFO;
viewportState.viewportCount = 1;
viewportState.pViewports = &viewport;
viewportState.scissorCount = 1;
viewportState.pScissors = &scissor;
VkPipelineRasterizationStateCreateInfo rasterizer = {};
rasterizer.sType = VK_STRUCTURE_TYPE_PIPELINE_RASTERIZATION_STATE_CREATE_INFO;
rasterizer.depthClampEnable = VK_FALSE;
rasterizer.rasterizerDiscardEnable = VK_FALSE;
rasterizer.polygonMode = VK_POLYGON_MODE_FILL;
rasterizer.lineWidth = 1.0f;
rasterizer.cullMode = VK_CULL_MODE_BACK_BIT;
rasterizer.frontFace = VK_FRONT_FACE_CLOCKWISE;
rasterizer.depthBiasEnable = VK_FALSE;
VkPipelineMultisampleStateCreateInfo multisampling = {};
multisampling.sType = VK_STRUCTURE_TYPE_PIPELINE_MULTISAMPLE_STATE_CREATE_INFO;
multisampling.sampleShadingEnable = VK_FALSE;
multisampling.rasterizationSamples = VK_SAMPLE_COUNT_1_BIT;
VkPipelineColorBlendAttachmentState colorBlendAttachment = {};
colorBlendAttachment.colorWriteMask = VK_COLOR_COMPONENT_R_BIT | VK_COLOR_COMPONENT_G_BIT | VK_COLOR_COMPONENT_B_BIT | VK_COLOR_COMPONENT_A_BIT;
colorBlendAttachment.blendEnable = VK_FALSE;
VkPipelineColorBlendStateCreateInfo colorBlending = {};
colorBlending.sType = VK_STRUCTURE_TYPE_PIPELINE_COLOR_BLEND_STATE_CREATE_INFO;
colorBlending.logicOpEnable = VK_FALSE;
colorBlending.logicOp = VK_LOGIC_OP_COPY;
colorBlending.attachmentCount = 1;
colorBlending.pAttachments = &colorBlendAttachment;
colorBlending.blendConstants[0] = 0.0f;
colorBlending.blendConstants[1] = 0.0f;
colorBlending.blendConstants[2] = 0.0f;
colorBlending.blendConstants[3] = 0.0f;
VkGraphicsPipelineCreateInfo pipelineInfo = {};
pipelineInfo.sType = VK_STRUCTURE_TYPE_GRAPHICS_PIPELINE_CREATE_INFO;
pipelineInfo.stageCount = 2;
pipelineInfo.pStages = shaderStages;
pipelineInfo.pVertexInputState = &vertexInputInfo;
pipelineInfo.pInputAssemblyState = &inputAssembly;
pipelineInfo.pViewportState = &viewportState;
pipelineInfo.pRasterizationState = &rasterizer;
pipelineInfo.pMultisampleState = &multisampling;
pipelineInfo.pColorBlendState = &colorBlending;
pipelineInfo.layout = *pipelineLayout;
pipelineInfo.renderPass = *renderPass;
pipelineInfo.subpass = 0;
pipelineInfo.basePipelineHandle = VK_NULL_HANDLE;
printf("creating pipeline!\n");
VK_ASSERT(vkCreateGraphicsPipelines(*device, VK_NULL_HANDLE, 1, &pipelineInfo, VK_NULL_HANDLE, graphicsPipeline));
printf("pipeline created!\n");
}
VkShaderModule createShaderModule(VkDevice device, const uint32_t *code, size_t size) {
VkShaderModule module;
VkShaderModuleCreateInfo shaderCreateInfo =
{
.sType = VK_STRUCTURE_TYPE_SHADER_MODULE_CREATE_INFO,
.pNext = VK_NULL_HANDLE,
.flags = 0,
.codeSize = size,
.pCode = code,
};
vkCreateShaderModule(device, &shaderCreateInfo, VK_NULL_HANDLE, &module);
return module;
}
static VKAPI_ATTR VkBool32 VKAPI_CALL debugCallback(VkDebugUtilsMessageSeverityFlagBitsEXT messageSeverity, VkDebugUtilsMessageTypeFlagsEXT messageType, const VkDebugUtilsMessengerCallbackDataEXT *pCallbackData, void *pUserData)
{
printf("%s\n", pCallbackData->pMessage);
return VK_FALSE;
}
static void vui_createVulkanMessenger(VkInstance instance, VkDebugUtilsMessengerEXT *callback)
{
PFN_vkCreateDebugUtilsMessengerEXT funcPointer = (PFN_vkCreateDebugUtilsMessengerEXT) vkGetInstanceProcAddr(instance, "vkCreateDebugUtilsMessengerEXT");
EXIT_ON_NULL(funcPointer);
VkDebugUtilsMessengerCreateInfoEXT debugUtilsMessengerInfo =
{
.sType = VK_STRUCTURE_TYPE_DEBUG_UTILS_MESSENGER_CREATE_INFO_EXT,
.pNext = VK_NULL_HANDLE,
.flags = 0,
.messageSeverity = VK_DEBUG_UTILS_MESSAGE_SEVERITY_WARNING_BIT_EXT | VK_DEBUG_UTILS_MESSAGE_SEVERITY_ERROR_BIT_EXT | VK_DEBUG_UTILS_MESSAGE_SEVERITY_INFO_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,
.pfnUserCallback = debugCallback,
.pUserData = VK_NULL_HANDLE
};
VK_ASSERT(funcPointer(instance, &debugUtilsMessengerInfo, VK_NULL_HANDLE, callback));
}
Спасибо, что прочитали это, Оджад