vkCreateGraphicsPipelines 段错误在共享库中但不在静态库中

vkCreateGraphicsPipelines segfault's in shared library but not in static library

我正在尝试编写一个共享库(在 c 中),它应该启动 vulkan(除其他外)。通过启动我的意思是它应该完成从实例创建到管道创建的整个设置链。

当我将上述函数作为静态库函数调用时 -> 一切正常,并且在 vkCreateGraphicsPipelines 中没有出现段错误。但是,当我构建与共享 (.so) 库相同的函数并调用它时 -> vkCreateGraphicsPipelines segfault's.

更新 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));
}

感谢您阅读本文,Ojad

中的段错误
#0  0x00007ffff7fc37db in crc32 () from /usr/local/lib/libvui.so.0

是由声明冲突引起的。基本上,我包含了一个包含名为 crc32 的函数的库。 libvulkan_intel.so 中某处或至少某处作为外部依赖项必须有一个具有相同声明的函数。无论哪种方式,当作为共享库编译时,我有效地覆盖了 crc32,这在调用 crc32 时导致了段错误。这不是我最引以为豪的错误,但它确实发生了。