2021-01-16 22:22:31 +01:00
|
|
|
#pragma once
|
|
|
|
#include "vk_common.h"
|
|
|
|
|
2021-01-09 22:21:58 +01:00
|
|
|
#include "xash3d_types.h"
|
2021-01-16 22:22:31 +01:00
|
|
|
#include "com_strings.h" // S_ERROR
|
2021-01-09 22:21:58 +01:00
|
|
|
|
2021-01-13 20:54:34 +01:00
|
|
|
#define VK_NO_PROTOTYPES
|
|
|
|
#include <vulkan/vulkan.h>
|
|
|
|
|
2021-01-09 22:21:58 +01:00
|
|
|
qboolean R_VkInit( void );
|
|
|
|
void R_VkShutdown( void );
|
2021-01-13 20:54:34 +01:00
|
|
|
|
|
|
|
// FIXME load from embedded static structs
|
|
|
|
VkShaderModule loadShader(const char *filename);
|
2021-01-16 22:22:31 +01:00
|
|
|
VkSemaphore createSemaphore( void );
|
|
|
|
void destroySemaphore(VkSemaphore sema);
|
|
|
|
VkFence createFence( void );
|
|
|
|
void destroyFence(VkFence fence);
|
2021-01-13 20:54:34 +01:00
|
|
|
|
2021-01-17 00:45:10 +01:00
|
|
|
// FIXME arena allocation, ...
|
|
|
|
typedef struct device_memory_s
|
|
|
|
{
|
|
|
|
VkDeviceMemory device_memory;
|
|
|
|
uint32_t offset;
|
|
|
|
} device_memory_t;
|
|
|
|
|
2021-02-28 00:40:57 +01:00
|
|
|
device_memory_t allocateDeviceMemory(VkMemoryRequirements req, VkMemoryPropertyFlags props, VkMemoryAllocateFlags flags);
|
2021-01-17 00:45:10 +01:00
|
|
|
void freeDeviceMemory(device_memory_t *mem);
|
|
|
|
|
|
|
|
typedef struct vk_buffer_s
|
|
|
|
{
|
|
|
|
device_memory_t device_memory;
|
|
|
|
VkBuffer buffer;
|
|
|
|
|
|
|
|
void *mapped;
|
|
|
|
uint32_t size;
|
|
|
|
} vk_buffer_t;
|
|
|
|
|
2021-01-13 20:54:34 +01:00
|
|
|
typedef struct physical_device_s {
|
|
|
|
VkPhysicalDevice device;
|
|
|
|
VkPhysicalDeviceMemoryProperties memory_properties;
|
|
|
|
VkPhysicalDeviceProperties properties;
|
2021-05-08 23:30:33 +02:00
|
|
|
VkPhysicalDeviceProperties2 properties2;
|
|
|
|
VkPhysicalDeviceAccelerationStructurePropertiesKHR properties_accel;
|
2021-07-05 22:24:57 +02:00
|
|
|
VkPhysicalDeviceRayTracingPipelinePropertiesKHR properties_ray_tracing_pipeline;
|
2021-01-13 20:54:34 +01:00
|
|
|
} physical_device_t;
|
|
|
|
|
|
|
|
typedef struct vulkan_core_s {
|
|
|
|
uint32_t vulkan_version;
|
|
|
|
VkInstance instance;
|
|
|
|
VkDebugUtilsMessengerEXT debug_messenger;
|
|
|
|
|
2021-06-07 09:16:54 +02:00
|
|
|
poolhandle_t pool;
|
2021-01-13 20:54:34 +01:00
|
|
|
|
2021-03-07 01:40:35 +01:00
|
|
|
// TODO store important capabilities that affect render code paths
|
|
|
|
// (as rtx, dedicated gpu memory, bindless, etc) separately in a struct
|
2021-02-22 18:46:29 +01:00
|
|
|
qboolean debug, rtx;
|
2021-01-18 19:54:48 +01:00
|
|
|
struct {
|
|
|
|
VkSurfaceKHR surface;
|
|
|
|
uint32_t num_surface_formats;
|
|
|
|
VkSurfaceFormatKHR *surface_formats;
|
|
|
|
|
|
|
|
uint32_t num_present_modes;
|
|
|
|
VkPresentModeKHR *present_modes;
|
|
|
|
} surface;
|
2021-01-13 20:54:34 +01:00
|
|
|
|
|
|
|
physical_device_t physical_device;
|
|
|
|
VkDevice device;
|
|
|
|
VkQueue queue;
|
|
|
|
|
2021-01-13 21:10:36 +01:00
|
|
|
VkCommandPool command_pool;
|
|
|
|
VkCommandBuffer cb;
|
2021-05-28 19:10:20 +02:00
|
|
|
VkCommandBuffer cb_tex;
|
2021-01-17 00:45:10 +01:00
|
|
|
|
|
|
|
vk_buffer_t staging;
|
2021-01-17 02:02:43 +01:00
|
|
|
|
|
|
|
VkSampler default_sampler;
|
2021-01-13 20:54:34 +01:00
|
|
|
} vulkan_core_t;
|
|
|
|
|
|
|
|
extern vulkan_core_t vk_core;
|
|
|
|
|
|
|
|
const char *resultName(VkResult result);
|
|
|
|
|
2021-05-17 19:36:40 +02:00
|
|
|
#define SET_DEBUG_NAME(object, type, name) \
|
|
|
|
do { \
|
|
|
|
if (vk_core.debug) { \
|
|
|
|
VkDebugUtilsObjectNameInfoEXT duoni = { \
|
|
|
|
.sType = VK_STRUCTURE_TYPE_DEBUG_UTILS_OBJECT_NAME_INFO_EXT, \
|
|
|
|
.objectHandle = (uint64_t)object, \
|
|
|
|
.objectType = type, \
|
|
|
|
.pObjectName = name, \
|
|
|
|
}; \
|
|
|
|
XVK_CHECK(vkSetDebugUtilsObjectNameEXT(vk_core.device, &duoni)); \
|
|
|
|
} \
|
|
|
|
} while (0)
|
|
|
|
|
2021-01-13 20:54:34 +01:00
|
|
|
// TODO make this not fatal: devise proper error handling strategies
|
|
|
|
// FIXME Host_Error does not cause process to exit, we need to handle this manually
|
|
|
|
#define XVK_CHECK(f) do { \
|
|
|
|
const VkResult result = f; \
|
|
|
|
if (result != VK_SUCCESS) { \
|
2021-05-28 19:10:20 +02:00
|
|
|
gEngine.Con_Printf( S_ERROR "%s:%d " #f " failed (%d): %s\n", \
|
|
|
|
__FILE__, __LINE__, result, resultName(result)); \
|
2021-01-13 20:54:34 +01:00
|
|
|
gEngine.Host_Error( S_ERROR "%s:%d " #f " failed (%d): %s\n", \
|
|
|
|
__FILE__, __LINE__, result, resultName(result)); \
|
|
|
|
} \
|
|
|
|
} while(0)
|
|
|
|
|
2021-01-18 19:54:48 +01:00
|
|
|
#define INSTANCE_FUNCS(X) \
|
|
|
|
X(vkDestroyInstance) \
|
|
|
|
X(vkEnumeratePhysicalDevices) \
|
|
|
|
X(vkGetPhysicalDeviceProperties) \
|
|
|
|
X(vkGetPhysicalDeviceProperties2) \
|
|
|
|
X(vkGetPhysicalDeviceFeatures2) \
|
|
|
|
X(vkGetPhysicalDeviceQueueFamilyProperties) \
|
|
|
|
X(vkGetPhysicalDeviceSurfaceSupportKHR) \
|
|
|
|
X(vkGetPhysicalDeviceMemoryProperties) \
|
|
|
|
X(vkGetPhysicalDeviceSurfacePresentModesKHR) \
|
|
|
|
X(vkGetPhysicalDeviceSurfaceFormatsKHR) \
|
|
|
|
X(vkGetPhysicalDeviceSurfaceCapabilitiesKHR) \
|
2021-01-23 19:54:44 +01:00
|
|
|
X(vkGetPhysicalDeviceFormatProperties) \
|
2021-01-18 19:54:48 +01:00
|
|
|
X(vkCreateDevice) \
|
|
|
|
X(vkGetDeviceProcAddr) \
|
|
|
|
X(vkDestroyDevice) \
|
|
|
|
X(vkDestroySurfaceKHR) \
|
2021-02-22 18:46:29 +01:00
|
|
|
X(vkEnumerateDeviceExtensionProperties) \
|
2021-01-18 19:54:48 +01:00
|
|
|
|
2021-02-01 01:50:27 +01:00
|
|
|
#define INSTANCE_DEBUG_FUNCS(X) \
|
|
|
|
X(vkCreateDebugUtilsMessengerEXT) \
|
|
|
|
X(vkDestroyDebugUtilsMessengerEXT) \
|
|
|
|
X(vkCmdBeginDebugUtilsLabelEXT) \
|
|
|
|
X(vkCmdEndDebugUtilsLabelEXT) \
|
|
|
|
X(vkCmdInsertDebugUtilsLabelEXT) \
|
|
|
|
X(vkSetDebugUtilsObjectNameEXT) \
|
|
|
|
|
2021-01-13 20:54:34 +01:00
|
|
|
#define DEVICE_FUNCS(X) \
|
|
|
|
X(vkGetDeviceQueue) \
|
|
|
|
X(vkCreateSwapchainKHR) \
|
|
|
|
X(vkGetSwapchainImagesKHR) \
|
|
|
|
X(vkDestroySwapchainKHR) \
|
|
|
|
X(vkCreateImageView) \
|
|
|
|
X(vkCreateFramebuffer) \
|
|
|
|
X(vkCreateRenderPass) \
|
2021-02-06 20:38:21 +01:00
|
|
|
X(vkCreatePipelineCache) \
|
|
|
|
X(vkDestroyPipelineCache) \
|
2021-01-13 20:54:34 +01:00
|
|
|
X(vkCreatePipelineLayout) \
|
|
|
|
X(vkCreateGraphicsPipelines) \
|
|
|
|
X(vkCreateShaderModule) \
|
2021-01-13 21:10:36 +01:00
|
|
|
X(vkCreateCommandPool) \
|
|
|
|
X(vkAllocateCommandBuffers) \
|
2021-01-16 22:22:31 +01:00
|
|
|
X(vkCreateBuffer) \
|
|
|
|
X(vkGetBufferMemoryRequirements) \
|
|
|
|
X(vkAllocateMemory) \
|
|
|
|
X(vkBindBufferMemory) \
|
|
|
|
X(vkMapMemory) \
|
|
|
|
X(vkUnmapMemory) \
|
|
|
|
X(vkDestroyBuffer) \
|
|
|
|
X(vkFreeMemory) \
|
|
|
|
X(vkAcquireNextImageKHR) \
|
|
|
|
X(vkCmdBeginRenderPass) \
|
|
|
|
X(vkCmdExecuteCommands) \
|
|
|
|
X(vkCmdEndRenderPass) \
|
|
|
|
X(vkEndCommandBuffer) \
|
|
|
|
X(vkQueueSubmit) \
|
|
|
|
X(vkQueuePresentKHR) \
|
|
|
|
X(vkWaitForFences) \
|
|
|
|
X(vkResetFences) \
|
|
|
|
X(vkCreateSemaphore) \
|
|
|
|
X(vkDestroySemaphore) \
|
|
|
|
X(vkCreateFence) \
|
|
|
|
X(vkDestroyFence) \
|
|
|
|
X(vkBeginCommandBuffer) \
|
|
|
|
X(vkCmdBindPipeline) \
|
|
|
|
X(vkCmdBindVertexBuffers) \
|
|
|
|
X(vkCmdDraw) \
|
2021-01-16 22:49:07 +01:00
|
|
|
X(vkDestroyCommandPool) \
|
|
|
|
X(vkDestroyImageView) \
|
|
|
|
X(vkDestroyFramebuffer) \
|
|
|
|
X(vkDestroyRenderPass) \
|
|
|
|
X(vkDestroyShaderModule) \
|
|
|
|
X(vkDestroyPipeline) \
|
|
|
|
X(vkDestroyPipelineLayout) \
|
2021-01-17 00:45:10 +01:00
|
|
|
X(vkCreateImage) \
|
|
|
|
X(vkGetImageMemoryRequirements) \
|
|
|
|
X(vkBindImageMemory) \
|
|
|
|
X(vkCmdPipelineBarrier) \
|
|
|
|
X(vkCmdCopyBufferToImage) \
|
|
|
|
X(vkQueueWaitIdle) \
|
|
|
|
X(vkDestroyImage) \
|
2021-01-17 02:02:43 +01:00
|
|
|
X(vkCmdBindDescriptorSets) \
|
|
|
|
X(vkCreateSampler) \
|
|
|
|
X(vkDestroySampler) \
|
|
|
|
X(vkCreateDescriptorPool) \
|
|
|
|
X(vkDestroyDescriptorPool) \
|
|
|
|
X(vkCreateDescriptorSetLayout) \
|
|
|
|
X(vkAllocateDescriptorSets) \
|
|
|
|
X(vkUpdateDescriptorSets) \
|
2021-01-18 19:54:48 +01:00
|
|
|
X(vkDestroyDescriptorSetLayout) \
|
2021-01-18 20:15:51 +01:00
|
|
|
X(vkCmdSetViewport) \
|
|
|
|
X(vkCmdSetScissor) \
|
2021-01-24 04:38:00 +01:00
|
|
|
X(vkCmdUpdateBuffer) \
|
|
|
|
X(vkCmdBindIndexBuffer) \
|
|
|
|
X(vkCmdDrawIndexed) \
|
2021-03-01 19:52:08 +01:00
|
|
|
X(vkCmdPushConstants) \
|
|
|
|
X(vkCreateComputePipelines) \
|
|
|
|
X(vkCmdDispatch) \
|
2021-03-20 19:15:57 +01:00
|
|
|
X(vkCmdBlitImage) \
|
2021-03-20 21:42:15 +01:00
|
|
|
X(vkCmdClearColorImage) \
|
2021-01-13 20:54:34 +01:00
|
|
|
|
2021-02-27 22:43:49 +01:00
|
|
|
#define DEVICE_FUNCS_RTX(X) \
|
|
|
|
X(vkGetAccelerationStructureBuildSizesKHR) \
|
|
|
|
X(vkCreateAccelerationStructureKHR) \
|
|
|
|
X(vkGetBufferDeviceAddress) \
|
|
|
|
X(vkCmdBuildAccelerationStructuresKHR) \
|
|
|
|
X(vkDestroyAccelerationStructureKHR) \
|
2021-03-01 19:52:08 +01:00
|
|
|
X(vkGetAccelerationStructureDeviceAddressKHR) \
|
2021-07-05 22:24:57 +02:00
|
|
|
X(vkCmdTraceRaysKHR) \
|
|
|
|
X(vkCreateRayTracingPipelinesKHR) \
|
|
|
|
X(vkGetRayTracingShaderGroupHandlesKHR) \
|
2021-02-27 22:43:49 +01:00
|
|
|
|
2021-01-13 20:54:34 +01:00
|
|
|
#define X(f) extern PFN_##f f;
|
|
|
|
DEVICE_FUNCS(X)
|
2021-02-27 22:43:49 +01:00
|
|
|
DEVICE_FUNCS_RTX(X)
|
2021-01-18 19:54:48 +01:00
|
|
|
INSTANCE_FUNCS(X)
|
2021-02-01 01:50:27 +01:00
|
|
|
INSTANCE_DEBUG_FUNCS(X)
|
2021-01-13 20:54:34 +01:00
|
|
|
#undef X
|