mirror of
https://git.code.sf.net/p/quake/quakeforge
synced 2024-11-23 21:02:50 +00:00
8b85e422d7
The stack is arbitrary strings that the validation layer debug callback prints in reverse order after each message. This makes it easy to work out what nodes in a pipeline/render pass plist are causing validation errors. Still have to narrow down the actual line, but the messages seem to help with that. Putting qfvPushDebug/qfvPopDebug around other calls to vulkan should help out a lot, tool. As a bonus, the stack is printed before debug_breakpoint is called, so it's immediately visible in gdb.
127 lines
3.6 KiB
C
127 lines
3.6 KiB
C
#ifndef __vid_vulkan_h
|
|
#define __vid_vulkan_h
|
|
|
|
#ifndef VK_NO_PROTOTYPES
|
|
#define VK_NO_PROTOTYPES
|
|
#endif
|
|
#include <vulkan/vulkan.h>
|
|
|
|
#include "QF/darray.h"
|
|
#include "QF/simd/types.h"
|
|
|
|
typedef struct vulkan_frame_s {
|
|
VkFramebuffer framebuffer;
|
|
VkFence fence;
|
|
VkSemaphore imageAvailableSemaphore;
|
|
VkSemaphore renderDoneSemaphore;
|
|
VkCommandBuffer cmdBuffer;
|
|
|
|
int cmdSetCount;
|
|
struct qfv_cmdbufferset_s *cmdSets;
|
|
} vulkan_frame_t;
|
|
|
|
typedef struct vulkan_matrices_s {
|
|
VkBuffer buffer_2d;
|
|
VkBuffer buffer_3d;
|
|
VkDeviceMemory memory;
|
|
vec4f_t *projection_2d;
|
|
vec4f_t *projection_3d;
|
|
vec4f_t *view_3d;
|
|
vec4f_t *sky_3d;
|
|
} vulkan_matrices_t;
|
|
|
|
typedef struct vulkan_frameset_s
|
|
DARRAY_TYPE (vulkan_frame_t) vulkan_frameset_t;
|
|
|
|
typedef struct clearvalueset_s
|
|
DARRAY_TYPE (VkClearValue) clearvalueset_t;
|
|
|
|
typedef struct vulkan_ctx_s {
|
|
void (*load_vulkan) (struct vulkan_ctx_s *ctx);
|
|
void (*unload_vulkan) (struct vulkan_ctx_s *ctx);
|
|
|
|
const char **required_extensions;
|
|
struct vulkan_presentation_s *presentation;
|
|
int (*get_presentation_support) (struct vulkan_ctx_s *ctx,
|
|
VkPhysicalDevice physicalDevice,
|
|
uint32_t queueFamilyIndex);
|
|
void (*choose_visual) (struct vulkan_ctx_s *ctx);
|
|
void (*create_window) (struct vulkan_ctx_s *ctx);
|
|
VkSurfaceKHR (*create_surface) (struct vulkan_ctx_s *ctx);
|
|
|
|
struct va_ctx_s *va_ctx;
|
|
struct qfv_instance_s *instance;
|
|
struct qfv_device_s *device;
|
|
struct qfv_swapchain_s *swapchain;
|
|
VkSampleCountFlagBits msaaSamples; // FIXME not here?
|
|
struct hashlink_s *hashlinks; //FIXME want per thread
|
|
VkSurfaceKHR surface; //FIXME surface = window, so "contains" swapchain
|
|
struct plitem_s *pipelineDef;
|
|
|
|
struct plitem_s *renderpassDef;
|
|
VkRenderPass renderpass;
|
|
clearvalueset_t *clearValues;
|
|
struct qfv_imageset_s *attachment_images;
|
|
struct qfv_imageviewset_s *attachment_views;
|
|
VkDeviceMemory attachmentMemory;
|
|
|
|
uint32_t swapImageIndex;
|
|
struct qfv_framebufferset_s *framebuffers;
|
|
|
|
struct hashtab_s *shaderModules;
|
|
struct hashtab_s *setLayouts;
|
|
struct hashtab_s *pipelineLayouts;
|
|
struct hashtab_s *descriptorPools;
|
|
struct hashtab_s *samplers;
|
|
struct hashtab_s *images;
|
|
struct hashtab_s *imageViews;
|
|
struct hashtab_s *renderpasses;
|
|
|
|
struct aliasctx_s *alias_context;
|
|
struct bspctx_s *bsp_context;
|
|
struct drawctx_s *draw_context;
|
|
struct lightingctx_s *lighting_context;
|
|
struct composectx_s *compose_context;
|
|
|
|
VkBuffer quad_buffer;
|
|
VkDeviceMemory quad_memory;
|
|
|
|
VkCommandPool cmdpool;
|
|
VkCommandBuffer cmdbuffer;
|
|
VkFence fence; // for ctx->cmdbuffer only
|
|
struct qfv_stagebuf_s *staging;
|
|
size_t curFrame;
|
|
vulkan_frameset_t frames;
|
|
|
|
struct qfv_capture_s *capture;
|
|
void (*capture_callback) (const byte *data, int width, int height);
|
|
|
|
struct qfv_tex_s *default_black;
|
|
struct qfv_tex_s *default_white;
|
|
struct qfv_tex_s *default_magenta;
|
|
|
|
VkViewport viewport;
|
|
VkRect2D scissor;
|
|
// projection and view matrices (model is push constant)
|
|
vulkan_matrices_t matrices;
|
|
|
|
#define EXPORTED_VULKAN_FUNCTION(fname) PFN_##fname fname;
|
|
#define GLOBAL_LEVEL_VULKAN_FUNCTION(fname) PFN_##fname fname;
|
|
#include "QF/Vulkan/funclist.h"
|
|
} vulkan_ctx_t;
|
|
|
|
#define qfvPushDebug(ctx, x) \
|
|
do { \
|
|
if (developer->int_val & SYS_vulkan) { \
|
|
DARRAY_APPEND(&(ctx)->instance->debug_stack, (x)); \
|
|
} \
|
|
} while (0)
|
|
#define qfvPopDebug(ctx) \
|
|
do { \
|
|
if (developer->int_val & SYS_vulkan) { \
|
|
__auto_type ds = &(ctx)->instance->debug_stack; \
|
|
DARRAY_REMOVE_AT(ds, ds->size - 1); \
|
|
} \
|
|
} while (0)
|
|
|
|
#endif//__vid_vulkan_h
|