diff options
author | grm <grm@eyesin.space> | 2024-05-21 11:56:12 +0300 |
---|---|---|
committer | grm <grm@eyesin.space> | 2024-05-21 11:56:12 +0300 |
commit | 2017b06f2d3fc254a188352f8b3ca7266a99ec09 (patch) | |
tree | 91be243faa9c06f22379e8e774b14463b285a47b | |
parent | af064c2411f101c500628b791e712f586953e84b (diff) | |
download | cgame-2017b06f2d3fc254a188352f8b3ca7266a99ec09.tar.gz cgame-2017b06f2d3fc254a188352f8b3ca7266a99ec09.tar.bz2 cgame-2017b06f2d3fc254a188352f8b3ca7266a99ec09.zip |
hot reload shaders bby
-rw-r--r-- | configure.ac | 2 | ||||
-rw-r--r-- | src/Makefile.am | 2 | ||||
-rw-r--r-- | src/game.c | 41 | ||||
-rw-r--r-- | src/shader.frag | 32 | ||||
-rw-r--r-- | src/shader.vert | 5 | ||||
-rw-r--r-- | src/state.h | 12 | ||||
-rw-r--r-- | src/vkutil.h | 2 |
7 files changed, 75 insertions, 21 deletions
diff --git a/configure.ac b/configure.ac index 167f0a7..2e82426 100644 --- a/configure.ac +++ b/configure.ac @@ -18,7 +18,7 @@ AM_INIT_AUTOMAKE([-Wall -Werror foreign subdir-objects dist-xz]) AC_LANG([C]) AC_LANG([C++]) -AC_PROG_CXX(clang) +AC_PROG_CXX([clang]) AC_PROG_CC([clang]) # Set default cflags diff --git a/src/Makefile.am b/src/Makefile.am index 7ef364b..bf53524 100644 --- a/src/Makefile.am +++ b/src/Makefile.am @@ -21,6 +21,6 @@ AM_CFLAGS = -march=native -fno-math-errno -funroll-loops -flto -pthread -ggdb -D AM_CXXFLAGS = -Wall -Wextra -O2 -g -std=c++17 game_SOURCES = game.c cplusplus.cpp $(common_sources) -game_LDADD = -lSDL2 -lm -lSDL2_image -lvulkan -lshaderc_shared -lstdc++ +game_LDADD = -lSDL2 -lm -lvulkan -lshaderc_shared -lstdc++ cplusplus.$(OBJEXT) : CXXFLAGS += -Wno-nullability-completeness -Wno-unused-function -Wno-missing-field-initializers -Wno-unused-parameter -Wno-unused-variable @@ -1,4 +1,3 @@ -#include <limits.h> #include <stdbool.h> #include <stdlib.h> #include <time.h> @@ -8,7 +7,6 @@ #define SDL_MAIN_HANDLED #define VK_USE_PLATFORM_XCB_KHR #include <SDL2/SDL.h> -#include <SDL2/SDL_image.h> #include <SDL2/SDL_vulkan.h> #include <vulkan/vulkan.h> @@ -23,9 +21,6 @@ #include "state.h" // embedded clgm library -#define CGLM_FORCE_DEPTH_ZERO_TO_ONE -#include "../lib/cglm/include/cglm/cglm.h" - uint32_t currentFrame = 0; state_t s; @@ -727,11 +722,21 @@ vulkan_create_graphics_pipeline() shaderc_compilation_result_t vert_result = load_compile_shader_data("src/shader.vert", shaderc_vertex_shader); if (!vert_result) { vk_log(VK_ERROR, "Can't load vertex shader\n"); + if (s.prev_vert_result) { + vert_result = s.prev_vert_result; + } } + if (s.prev_vert_result && vert_result != s.prev_vert_result) shaderc_result_release(s.prev_vert_result); + s.prev_vert_result = vert_result; shaderc_compilation_result_t frag_result = load_compile_shader_data("src/shader.frag", shaderc_fragment_shader); if (!frag_result) { vk_log(VK_ERROR, "Can't load fragment shader\n"); + if (s.prev_frag_result) { + frag_result = s.prev_frag_result; + } } + if (s.prev_frag_result && frag_result != s.prev_frag_result) shaderc_result_release(s.prev_frag_result); + s.prev_frag_result = frag_result; const char * vert_data = shaderc_result_get_bytes(vert_result); long vert_size = shaderc_result_get_length(vert_result); @@ -857,7 +862,7 @@ vulkan_create_graphics_pipeline() VkPipelineColorBlendStateCreateInfo colorBlending = {0}; colorBlending.sType = VK_STRUCTURE_TYPE_PIPELINE_COLOR_BLEND_STATE_CREATE_INFO; - colorBlending.logicOpEnable = VK_FALSE; + colorBlending.logicOpEnable = VK_TRUE; colorBlending.logicOp = VK_LOGIC_OP_COPY; // Optional colorBlending.attachmentCount = 1; colorBlending.pAttachments = &colorBlendAttachment; @@ -900,8 +905,12 @@ vulkan_create_graphics_pipeline() vk_log(VK_ERROR, "failed to create graphics pipeline!\n"); } - shaderc_result_release(vert_result); - shaderc_result_release(frag_result); + if (s.prev_vert_result != vert_result) { + shaderc_result_release(vert_result); + } + if (s.prev_frag_result != frag_result) { + shaderc_result_release(frag_result); + } vkDestroyShaderModule(s.vk_device, fragShaderModule, NULL); vkDestroyShaderModule(s.vk_device, vertShaderModule, NULL); @@ -1233,7 +1242,8 @@ vulkan_create_descriptor_set_layout() uboLayoutBinding.binding = 0; uboLayoutBinding.descriptorType = VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER; uboLayoutBinding.descriptorCount = 1; - uboLayoutBinding.stageFlags = VK_SHADER_STAGE_VERTEX_BIT; + uboLayoutBinding.stageFlags = VK_SHADER_STAGE_ALL; + //uboLayoutBinding.stageFlags = VK_SHADER_STAGE_VERTEX_BIT | VK_SHADER_STAGE_FRAGMENT_BIT; uboLayoutBinding.pImmutableSamplers = NULL; // optional VkDescriptorSetLayoutCreateInfo layoutInfo = {0}; @@ -1479,6 +1489,13 @@ close_vulkan() /* DestroyDebugUtilsMessengerEXT(s.vk_instance, s.vk_debug_messenger, NULL); */ /* } */ vkDestroyInstance(s.vk_instance, NULL); + + if (s.prev_vert_result) { + shaderc_result_release(s.prev_vert_result); + } + if (s.prev_frag_result) { + shaderc_result_release(s.prev_frag_result); + } } float @@ -1504,6 +1521,10 @@ updateUniformBuffer(uint32_t currentImage) float time = current_time(); UniformBufferObject ubo = {0}; + + ubo.resolution[0] = s.vk_swap_chain_extent.width; + ubo.resolution[1] = s.vk_swap_chain_extent.height; + glm_mat4_identity(ubo.model); if (s.rotate) @@ -1627,7 +1648,7 @@ main(int argc, char* args[]) while (!quit) { handle_input(&quit); draw_frame(); - //SDL_Delay(16); + SDL_Delay(16); } close_vulkan(); diff --git a/src/shader.frag b/src/shader.frag index cad317c..4702e65 100644 --- a/src/shader.frag +++ b/src/shader.frag @@ -5,8 +5,30 @@ layout(location = 1) in vec2 fragPos; layout(location = 0) out vec4 outColor; +layout(binding = 0) uniform UniformBufferObject { + mat4 model; + mat4 view; + mat4 proj; + vec2 resolution; +} ubo; + +// vec4 ubo_proj(vec2 v) { +// return ubo.proj * ubo.view * ubo.model * vec4(v, 0.0, 1.0); +// } + // void main() { -// outColor = vec4(fragColor, 1.0); +// // float x = gl_FragCoord.x / ubo.resolution.x; +// // float y = gl_FragCoord.y / ubo.resolution.y; +// float x = ubo_proj(vec2(gl_FragCoord.x, gl_FragCoord.y)).x / ubo.resolution.x; +// float y = ubo_proj(vec2(gl_FragCoord.x, gl_FragCoord.y)).y / ubo.resolution.y; +// //bool colored = mod(gl_FragCoord.x, 10) > 9 || mod(gl_FragCoord.y, 10) > 9; +// bool colored = mod(x,0.1) > 0.09 || mod(y, 0.1) > 0.09; +// if (colored) { +// outColor = vec4(gl_FragCoord.x / ubo.resolution.x, gl_FragCoord.y / ubo.resolution.y, 1.0, 1.0); +// } else { +// outColor = vec4(0,0,0, 1.0); +// } +// //outColor = vec4(fragColor, 1.0); // } vec3 mandel(vec2 z0) { float k = 0.0; @@ -20,13 +42,13 @@ vec3 mandel(vec2 z0) { return sin(mu*0.1 + vec3(0.0,0.5,1.0)); } void main() { - float ar = fragPos.x / fragPos.y; - vec2 uv = gl_FragCoord.xy / fragPos.yy - vec2(0.66 * ar, 0.5); - //uv = uv * 2.0 + vec2(-0.3, 1.0); + float ar = ubo.resolution.x / ubo.resolution.y; + vec2 uv = gl_FragCoord.xy / ubo.resolution.yy - vec2(0.66 * ar, 0.5); + // uv = uv * 2.0 + vec2(-0.3, 0.0); float p = 30.0; float t = mod(13.0, p); if (t > p/2.0) t = p - t; - float scale = 0.5 + pow(4.0, t); + float scale = 0.5 + pow(2.0, t); vec2 offset = vec2(-1.36799, .01); uv += offset*scale; uv /= scale; diff --git a/src/shader.vert b/src/shader.vert index 76de53c..f3355d1 100644 --- a/src/shader.vert +++ b/src/shader.vert @@ -4,6 +4,7 @@ layout(binding = 0) uniform UniformBufferObject { mat4 model; mat4 view; mat4 proj; + vec2 resolution; } ubo; layout(location = 0) in vec2 inPosition; @@ -13,8 +14,8 @@ layout(location = 0) out vec3 fragColor; layout(location = 1) out vec2 fragPos; void main() { - gl_Position = ubo.proj * ubo.view * ubo.model * vec4(inPosition, 0.0, 1.0); - //gl_Position = vec4(inPosition * 1.5, 1.0, 1.0); + //gl_Position = ubo.proj * ubo.view * ubo.model * vec4(inPosition * 2, 0.0, 1.0); + gl_Position = vec4(inPosition * 2, 0.0, 1.0); fragColor = inColor; fragPos = inPosition; } diff --git a/src/state.h b/src/state.h index 3890694..17be1c0 100644 --- a/src/state.h +++ b/src/state.h @@ -1,7 +1,10 @@ #include <SDL2/SDL.h> +#include <vulkan/vulkan.h> +#include <shaderc/shaderc.h> + +#define CGLM_FORCE_DEPTH_ZERO_TO_ONE #include "../lib/cglm/include/cglm/cglm.h" -#include <vulkan/vulkan.h> #pragma once @@ -22,6 +25,7 @@ typedef struct { mat4 model; mat4 view; mat4 proj; + vec2 resolution; } UniformBufferObject; typedef struct { @@ -98,6 +102,9 @@ typedef struct state { VkDeviceMemory vk_index_buffer_memory; VkDescriptorPool vk_descriptor_pool; + + shaderc_compilation_result_t prev_vert_result; + shaderc_compilation_result_t prev_frag_result; } state_t ; static void @@ -144,4 +151,7 @@ init_state(state_t * s) s->vk_physical_device = VK_NULL_HANDLE; s->vk_swap_chain_framebuffers_count = 0; + + s->prev_vert_result = NULL; + s->prev_frag_result = NULL; } diff --git a/src/vkutil.h b/src/vkutil.h index 9188a07..123b97a 100644 --- a/src/vkutil.h +++ b/src/vkutil.h @@ -29,7 +29,7 @@ typedef enum { VK_ERROR, } log_type; -void +static inline void vk_log(log_type t, const char * f, ...) { #ifdef VKDEBUG |