summaryrefslogtreecommitdiff
path: root/src/renderer/backends/backend_vulkan.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/renderer/backends/backend_vulkan.c')
-rw-r--r--src/renderer/backends/backend_vulkan.c29
1 files changed, 25 insertions, 4 deletions
diff --git a/src/renderer/backends/backend_vulkan.c b/src/renderer/backends/backend_vulkan.c
index ef266e0..2f8fdf7 100644
--- a/src/renderer/backends/backend_vulkan.c
+++ b/src/renderer/backends/backend_vulkan.c
@@ -40,6 +40,7 @@ typedef struct vulkan_context {
vulkan_swapchain_support_info swapchain_support;
arena temp_arena;
+ arena pool_arena;
gpu_device* device;
gpu_swapchain* swapchain;
u32 framebuffer_count;
@@ -66,6 +67,7 @@ typedef struct vulkan_context {
size_t buffer_count;
VkDescriptorSet_darray* free_set_queue;
struct resource_pools* resource_pools;
+ gpu_backend_pools gpu_pools;
VkDebugUtilsMessengerEXT vk_debugger;
} vulkan_context;
@@ -74,6 +76,8 @@ static vulkan_context context;
// --- Function forward declarations
+void backend_pools_init(arena* a, gpu_backend_pools* backend_pools);
+
/** @brief Enumerates and selects the most appropriate graphics device */
bool select_physical_device(gpu_device* out_device);
@@ -115,6 +119,11 @@ bool gpu_backend_init(const char* window_name, GLFWwindow* window) {
size_t temp_arena_size = 1024 * 1024;
context.temp_arena = arena_create(malloc(temp_arena_size), temp_arena_size);
+ size_t pool_buffer_size = 1024 * 1024;
+ context.pool_arena = arena_create(malloc(pool_buffer_size), pool_buffer_size);
+
+ backend_pools_init(&context.pool_arena, &context.gpu_pools);
+
// Setup Vulkan instance
VkApplicationInfo app_info = { VK_STRUCTURE_TYPE_APPLICATION_INFO };
app_info.apiVersion = VK_API_VERSION_1_2;
@@ -393,8 +402,9 @@ VkFormat format_from_vertex_attr(vertex_attrib_type attr) {
gpu_pipeline* gpu_graphics_pipeline_create(struct graphics_pipeline_desc description) {
// Allocate
- gpu_pipeline_layout* layout = malloc(sizeof(gpu_pipeline_layout));
- gpu_pipeline* pipeline = malloc(sizeof(gpu_pipeline));
+ gpu_pipeline_layout* layout =
+ pipeline_layout_pool_alloc(&context.gpu_pools.pipeline_layouts, NULL);
+ gpu_pipeline* pipeline = pipeline_pool_alloc(&context.gpu_pools.pipelines, NULL);
// Shaders
printf("Vertex shader: %s\n", description.vs.filepath.buf);
@@ -725,8 +735,7 @@ gpu_cmd_encoder* gpu_get_default_cmd_encoder() {
}
gpu_renderpass* gpu_renderpass_create(const gpu_renderpass_desc* description) {
- // TEMP: allocate with malloc. in the future we will have a pool allocator on the context
- gpu_renderpass* renderpass = malloc(sizeof(gpu_renderpass));
+ gpu_renderpass* renderpass = renderpass_pool_alloc(&context.gpu_pools.renderpasses, NULL);
// attachments
u32 attachment_desc_count = 2;
@@ -1687,3 +1696,15 @@ void resource_pools_init(arena* a, struct resource_pools* res_pools) {
context.resource_pools = res_pools;
}
+
+void backend_pools_init(arena* a, gpu_backend_pools* backend_pools) {
+ pipeline_layout_pool pipeline_layout_pool =
+ pipeline_layout_pool_create(a, MAX_PIPELINES, sizeof(gpu_pipeline_layout));
+ backend_pools->pipeline_layouts = pipeline_layout_pool;
+ pipeline_pool pipeline_pool = pipeline_pool_create(a, MAX_PIPELINES, sizeof(gpu_pipeline));
+ backend_pools->pipelines = pipeline_pool;
+ renderpass_pool rpass_pool = renderpass_pool_create(a, MAX_RENDERPASSES, sizeof(gpu_renderpass));
+ backend_pools->renderpasses = rpass_pool;
+
+ context.gpu_pools;
+}