summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--assets/shaders/cube.frag1
-rw-r--r--assets/shaders/debug_quad.frag3
-rw-r--r--examples/cube/ex_cube.c4
-rw-r--r--examples/shadow_maps/ex_shadow_maps.c129
-rw-r--r--src/maths/primitives.c30
-rw-r--r--src/renderer/backends/opengl/backend_opengl.c74
-rw-r--r--src/renderer/backends/opengl/backend_opengl.h3
-rw-r--r--src/renderer/ral.c6
-rw-r--r--src/renderer/ral.h2
-rw-r--r--src/renderer/render.c2
-rw-r--r--src/renderer/renderpasses.c28
11 files changed, 204 insertions, 78 deletions
diff --git a/assets/shaders/cube.frag b/assets/shaders/cube.frag
index cd6bb21..a405e6a 100644
--- a/assets/shaders/cube.frag
+++ b/assets/shaders/cube.frag
@@ -4,7 +4,6 @@ layout(location = 0) in vec3 fragColor;
layout(location = 1) in vec2 fragTexCoord;
uniform sampler2D texSampler;
-// uniform sampler2D texSampler;
layout(location = 0) out vec4 outColor;
diff --git a/assets/shaders/debug_quad.frag b/assets/shaders/debug_quad.frag
index ac7842d..877b26a 100644
--- a/assets/shaders/debug_quad.frag
+++ b/assets/shaders/debug_quad.frag
@@ -9,4 +9,5 @@ void main()
{
float depthValue = texture(depthMap, TexCoords).r;
FragColor = vec4(vec3(depthValue), 1.0); // orthographic
-} \ No newline at end of file
+ //FragColor = vec4(1.0);
+}
diff --git a/examples/cube/ex_cube.c b/examples/cube/ex_cube.c
index 3c98087..5a19f2c 100644
--- a/examples/cube/ex_cube.c
+++ b/examples/cube/ex_cube.c
@@ -46,7 +46,7 @@ shader_data_layout mvp_uniforms_layout(void* data) {
.stores_data = has_data,
.data = { .bytes = { .size = sizeof(mvp_uniforms) } } };
- shader_binding b2 = { .label = "texture_sampler",
+ shader_binding b2 = { .label = "texSampler",
.type = SHADER_BINDING_TEXTURE,
.stores_data = has_data };
if (has_data) {
@@ -75,7 +75,7 @@ int main() {
shader_data mvp_uniforms_data = { .data = NULL, .shader_data_get_layout = &mvp_uniforms_layout };
- gpu_renderpass_desc pass_description = {};
+ gpu_renderpass_desc pass_description = { .default_framebuffer = true };
gpu_renderpass* renderpass = gpu_renderpass_create(&pass_description);
str8 vert_path, frag_path;
diff --git a/examples/shadow_maps/ex_shadow_maps.c b/examples/shadow_maps/ex_shadow_maps.c
index 30df618..28cab86 100644
--- a/examples/shadow_maps/ex_shadow_maps.c
+++ b/examples/shadow_maps/ex_shadow_maps.c
@@ -2,6 +2,7 @@
#include "maths.h"
#include "maths_types.h"
#include "primitives.h"
+#include "log.h"
#include "ral.h"
#include "ral_types.h"
#include "render.h"
@@ -21,14 +22,96 @@ transform s_transforms[5];
*/
void draw_scene();
+void switch_view();
+
+enum active_view {
+ SceneView,
+ LightView,
+ DebugQuad,
+};
+
+// Define the shader data
+typedef struct mvp_uniforms {
+ mat4 model;
+ mat4 view;
+ mat4 projection;
+} mvp_uniforms;
+typedef struct my_shader_bind_group {
+ mvp_uniforms mvp;
+ texture_handle tex;
+} my_shader_bind_group;
+
+// We also must create a function that knows how to return a `shader_data_layout`
+shader_data_layout mvp_uniforms_layout(void* data) {
+ my_shader_bind_group* d = (my_shader_bind_group*)data;
+ bool has_data = data != NULL;
+
+ shader_binding b1 = { .label = "Matrices",
+ .type = SHADER_BINDING_BYTES,
+ .stores_data = has_data,
+ .data = { .bytes = { .size = sizeof(mvp_uniforms) } } };
+
+ shader_binding b2 = { .label = "texSampler",
+ .type = SHADER_BINDING_TEXTURE,
+ .stores_data = has_data };
+ if (has_data) {
+ b1.data.bytes.data = &d->mvp;
+ b2.data.texture.handle = d->tex;
+ }
+ return (shader_data_layout){ .name = "global_ubo", .bindings = { b1, b2 }, .bindings_count = 2 };
+}
int main() {
core_bringup();
arena scratch = arena_create(malloc(1024 * 1024), 1024 * 1024);
- vec3 camera_pos = vec3(2., 2., 2.);
+ vec3 camera_pos = vec3(5,5,5);
vec3 camera_front = vec3_normalise(vec3_negate(camera_pos));
camera cam = camera_create(camera_pos, camera_front, VEC3_Y, deg_to_rad(45.0));
+ // TEMP
+ shader_data mvp_uniforms_data = { .data = NULL, .shader_data_get_layout = &mvp_uniforms_layout };
+
+ gpu_renderpass_desc pass_description = { .default_framebuffer = true };
+ gpu_renderpass* renderpass = gpu_renderpass_create(&pass_description);
+
+ str8 vert_path, frag_path;
+#ifdef CEL_REND_BACKEND_OPENGL
+ vert_path = str8lit("assets/shaders/cube.vert");
+ frag_path = str8lit("assets/shaders/cube.frag");
+#else
+ vert_path = str8lit("build/linux/x86_64/debug/cube.vert.spv");
+ frag_path = str8lit("build/linux/x86_64/debug/cube.frag.spv");
+#endif
+ str8_opt vertex_shader = str8_from_file(&scratch, vert_path);
+ str8_opt fragment_shader = str8_from_file(&scratch, frag_path);
+ if (!vertex_shader.has_value || !fragment_shader.has_value) {
+ ERROR_EXIT("Failed to load shaders from disk")
+ }
+
+ struct graphics_pipeline_desc pipeline_description = {
+ .debug_name = "Basic Pipeline",
+ .vertex_desc = static_3d_vertex_description(),
+ .data_layouts = { mvp_uniforms_data },
+ .data_layouts_count = 1,
+ .vs = { .debug_name = "Cube Vertex Shader",
+ .filepath = vert_path,
+ .code = vertex_shader.contents,
+ .is_spirv = true },
+ .fs = { .debug_name = "Cube Fragment Shader",
+ .filepath = frag_path,
+ .code = fragment_shader.contents,
+ .is_spirv = true },
+ .renderpass = renderpass,
+ .wireframe = false,
+ .depth_test = false
+ };
+ gpu_pipeline* gfx_pipeline = gpu_graphics_pipeline_create(pipeline_description);
+
+ // Texture
+ texture_data tex_data = texture_data_load("assets/textures/texture.jpg", false);
+ texture_handle texture = texture_data_upload(tex_data, true);
+
+ // END TEMP
ren_shadowmaps shadows = { .width = 1000, .height = 1000 };
ren_shadowmaps_init(&shadows);
@@ -39,14 +122,14 @@ int main() {
// 2. lights
// 3. some boxes
for (int i = 0; i < 4; i++) {
- geometry_data geo = geo_create_cuboid(f32x3(2, 2, 2));
+ geometry_data geo = geo_create_cuboid(f32x3(1,1,1));
s_scene[i] = mesh_create(&geo, true);
- s_transforms[i] = transform_create(vec3(4 * i, 0, 0), quat_ident(), 1.0);
+ s_transforms[i] = transform_create(vec3(-2 + (i * 1.2), 0, 0), quat_ident(), 1.0);
}
geometry_data plane = geo_create_plane(f32x2(20, 20));
s_scene[4] = mesh_create(&plane, true);
- geometry_data quad_geo = geo_create_plane(f32x2(2,2));
+ geometry_data quad_geo = geo_create_plane(f32x2(2, 2));
mesh quad = mesh_create(&quad_geo, true);
shader_data model_data = { .data = NULL, .shader_data_get_layout = &model_uniform_layout };
@@ -61,7 +144,9 @@ int main() {
continue;
}
gpu_cmd_encoder* enc = gpu_get_default_cmd_encoder();
+ gpu_cmd_encoder_begin(*enc);
+ // Shadow draw
gpu_cmd_encoder_begin_render(enc, shadows.rpass);
// calculations
@@ -79,22 +164,49 @@ int main() {
draw_scene();
gpu_cmd_encoder_end_render(enc);
+ // End
+ // Debug quad
gpu_cmd_encoder_begin_render(enc, shadows.debug_quad->renderpass);
+
encode_bind_pipeline(enc, PIPELINE_GRAPHICS, shadows.debug_quad);
- debug_quad_uniform dqu = {.depthMap = shadows.depth_tex};
- shader_data debug_quad_data = { .data = &dqu, .shader_data_get_layout = debug_quad_layout};
+ debug_quad_uniform dqu = { .depthMap = shadows.depth_tex };
+ shader_data debug_quad_data = { .data = &dqu, .shader_data_get_layout = debug_quad_layout };
encode_bind_shader_data(enc, 0, &debug_quad_data);
encode_set_vertex_buffer(enc, quad.vertex_buffer);
encode_set_index_buffer(enc, quad.index_buffer);
encode_draw_indexed(enc, quad.geometry->indices->len);
gpu_cmd_encoder_end_render(enc);
+ // End
// gpu_cmd_encoder_begin_render(enc, static_opaque_rpass);
// gpu_cmd_encoder_end_render(enc);
+
+ /* gpu_cmd_encoder_begin_render(enc, renderpass); */
+ /* encode_bind_pipeline(enc, PIPELINE_GRAPHICS, gfx_pipeline); */
+
+ /* mat4 view, proj; */
+ /* camera_view_projection(&cam, 1000, 1000, */
+ /* &view, &proj); */
+ /* for (int i = 0; i < 4; i++) { */
+ /* mat4 model = transform_to_mat(&s_transforms[i]); */
+ /* mvp_uniforms mvp_data = { .model = model, .view = view, .projection = proj }; */
+ /* my_shader_bind_group shader_bind_data = { .mvp = mvp_data, .tex = texture }; */
+ /* mvp_uniforms_data.data = &shader_bind_data; */
+ /* encode_bind_shader_data(enc, 0, &mvp_uniforms_data); */
+ /* encode_set_vertex_buffer(enc, s_scene[i].vertex_buffer); */
+ /* encode_set_index_buffer(enc, s_scene[i].index_buffer); */
+ /* encode_draw_indexed(enc, s_scene[i].geometry->indices->len); */
+ /* } */
+
+ /* gpu_cmd_encoder_end_render(enc); */
+
+ // END drawing
+ gpu_cmd_buffer buf = gpu_cmd_encoder_finish(enc);
+ gpu_queue_submit(&buf);
gpu_backend_end_frame();
}
@@ -105,8 +217,9 @@ int main() {
void draw_scene() {
gpu_cmd_encoder* enc = gpu_get_default_cmd_encoder();
- for (int i = 0; i < 5; i++) {
- model_uniform mu = { .model = transform_to_mat(&s_transforms[i]) };
+ for (int i = 0; i < 4; i++) { //FIXME: draw plane as well
+ mat4 model = transform_to_mat(&s_transforms[i]) ;
+ model_uniform mu = { .model = model};
shader_data model_data = { .data = &mu, .shader_data_get_layout = model_uniform_layout };
encode_bind_shader_data(enc, 0, &model_data);
encode_set_vertex_buffer(enc, s_scene[i].vertex_buffer);
diff --git a/src/maths/primitives.c b/src/maths/primitives.c
index 57e85a2..ce467ab 100644
--- a/src/maths/primitives.c
+++ b/src/maths/primitives.c
@@ -5,6 +5,7 @@
#include "ral_types.h"
#include "render_types.h"
+// --- Helpers
#define VERT_3D(arr, pos, norm, uv) \
{ \
vertex v = { .static_3d = { .position = pos, .normal = norm, .tex_coords = uv } }; \
@@ -21,13 +22,8 @@ void push_triangle(u32_darray* arr, u32 i0, u32 i1, u32 i2) {
void geo_free_data(geometry_data* geo) {
vertex_darray_free(geo->vertices);
geo->vertices = NULL;
- // TODO: do indices as well
- /* if (geo->has_indices) { */
- /* u32_darray_free(&geo->indices); */
- /* } */
}
-// vertices
vec3 plane_vertex_positions[] = {
(vec3){ -0.5, 0, -0.5 },
(vec3){ 0.5, 0, -0.5 },
@@ -50,8 +46,8 @@ geometry_data geo_create_plane(f32x2 extents) {
VERT_3D(vertices, vert_pos[2], VEC3_Y, vec2(0, 1));
VERT_3D(vertices, vert_pos[3], VEC3_Y, vec2(1, 1));
- push_triangle(indices, 2, 1, 0);
- push_triangle(indices, 1, 2, 3);
+ push_triangle(indices, 0, 1, 2);
+ push_triangle(indices, 2, 1, 3);
geometry_data geo = { .format = VERTEX_STATIC_3D,
.vertices = vertices,
@@ -62,8 +58,6 @@ geometry_data geo_create_plane(f32x2 extents) {
return geo;
}
-// OLD
-
static const vec3 BACK_BOT_LEFT = (vec3){ 0, 0, 0 };
static const vec3 BACK_BOT_RIGHT = (vec3){ 1, 0, 0 };
static const vec3 BACK_TOP_LEFT = (vec3){ 0, 1, 0 };
@@ -74,7 +68,6 @@ static const vec3 FRONT_TOP_LEFT = (vec3){ 0, 1, 1 };
static const vec3 FRONT_TOP_RIGHT = (vec3){ 1, 1, 1 };
geometry_data geo_create_cuboid(f32x3 extents) {
- /* static mesh prim_cube_mesh_create() { */
vertex_darray* vertices = vertex_darray_new(36);
// back faces
@@ -142,19 +135,6 @@ geometry_data geo_create_cuboid(f32x3 extents) {
return geo;
}
-/* /\** @brief create a new model with the shape of a cube *\/ */
-/* static model_handle prim_cube_new(core* core) { */
-/* model model = { 0 }; */
-/* mesh cube = prim_cube_mesh_create(); */
-
-/* mesh_darray_push(model.meshes, cube); */
-/* assert(mesh_darray_len(model.meshes) == 1); */
-
-/* u32 index = (u32)model_darray_len(core->models); */
-/* model_darray_push_copy(core->models, &model); */
-/* return (model_handle){ .raw = index }; */
-/* } */
-
// --- Spheres
vec3 spherical_to_cartesian_coords(f32 rho, f32 theta, f32 phi) {
@@ -252,10 +232,6 @@ geometry_data geo_create_uvsphere(f32 radius, u32 north_south_lines, u32 east_we
}
}
- for (int i = 0; i < vertices->len; i++) {
- // print_vec3(vertices->data[i].static_3d.normal);
- }
-
geometry_data geo = {
.format = VERTEX_STATIC_3D,
.vertices = vertices,
diff --git a/src/renderer/backends/opengl/backend_opengl.c b/src/renderer/backends/opengl/backend_opengl.c
index 7d8aa01..02c27cd 100644
--- a/src/renderer/backends/opengl/backend_opengl.c
+++ b/src/renderer/backends/opengl/backend_opengl.c
@@ -70,7 +70,6 @@ void gpu_device_destroy() { /* No-op in OpenGL */ }
// --- Render Pipeline
gpu_pipeline* gpu_graphics_pipeline_create(struct graphics_pipeline_desc description) {
- static u32 ubo_count = 0;
gpu_pipeline* pipeline = pipeline_pool_alloc(&context.gpu_pools.pipelines, NULL);
// Create shader program
@@ -81,6 +80,7 @@ gpu_pipeline* gpu_graphics_pipeline_create(struct graphics_pipeline_desc descrip
pipeline->vertex_desc = description.vertex_desc;
// Allocate uniform buffers if needed
+ u32 ubo_count = 0;
// printf("data layouts %d\n", description.data_layouts_count);
for (u32 layout_i = 0; layout_i < description.data_layouts_count; layout_i++) {
shader_data_layout sdl = description.data_layouts[layout_i].shader_data_get_layout(NULL);
@@ -95,11 +95,11 @@ gpu_pipeline* gpu_graphics_pipeline_create(struct graphics_pipeline_desc descrip
buffer_handle ubo_handle =
gpu_buffer_create(binding.data.bytes.size, CEL_BUFFER_UNIFORM, CEL_BUFFER_FLAG_GPU,
NULL); // no data right now
- pipeline->uniform_bindings[binding_id] = ubo_handle;
+ pipeline->uniform_bindings[ubo_count++] = ubo_handle;
gpu_buffer* ubo_buf = BUFFER_GET(ubo_handle);
i32 blockIndex = glGetUniformBlockIndex(pipeline->shader_id, binding.label);
- printf("Block index for Matrices: %d", blockIndex);
+ printf("Block index for %s: %d", binding.label, blockIndex);
if (blockIndex < 0) {
WARN("Couldn't retrieve block index for uniform block '%s'", binding.label);
} else {
@@ -115,10 +115,12 @@ gpu_pipeline* gpu_graphics_pipeline_create(struct graphics_pipeline_desc descrip
glUniformBlockBinding(pipeline->shader_id, blockIndex, s_binding_point);
}
ubo_buf->ubo_binding_point = s_binding_point++;
+ ubo_buf->name = binding.label;
assert(s_binding_point < GL_MAX_UNIFORM_BUFFER_BINDINGS);
}
}
}
+ pipeline->uniform_count = ubo_count;
pipeline->renderpass = description.renderpass;
pipeline->wireframe = description.wireframe;
@@ -151,7 +153,7 @@ gpu_renderpass* gpu_renderpass_create(const gpu_renderpass_desc* description) {
}
if (description->has_depth_stencil) {
gpu_texture* depth_attachment = TEXTURE_GET(description->depth_stencil);
- glFramebufferTexture2D(GL_FRAMEBUFFER, GL_DEPTH_STENCIL_ATTACHMENT, GL_TEXTURE_2D,
+ glFramebufferTexture2D(GL_FRAMEBUFFER, GL_DEPTH_ATTACHMENT, GL_TEXTURE_2D,
depth_attachment->id, 0);
}
@@ -178,13 +180,20 @@ gpu_cmd_encoder gpu_cmd_encoder_create() {
void gpu_cmd_encoder_destroy(gpu_cmd_encoder* encoder) {}
void gpu_cmd_encoder_begin(gpu_cmd_encoder encoder) {}
void gpu_cmd_encoder_begin_render(gpu_cmd_encoder* encoder, gpu_renderpass* renderpass) {
- // glBindFramebuffer(GL_FRAMEBUFFER, renderpass->fbo);
+ glViewport(0, 0, 1000, 1000);
+ glBindFramebuffer(GL_FRAMEBUFFER, renderpass->fbo);
rgba clear_colour = STONE_800;
- glClearColor(clear_colour.r, clear_colour.g, clear_colour.b, 1.0f);
- glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
+ /* glClearColor(clear_colour.r, clear_colour.g, clear_colour.b, 1.0f); */
+ /* glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); */
+ // FIXME: account for both
+ if (renderpass->description.has_depth_stencil) {
+ glClear(GL_DEPTH_BUFFER_BIT);
+ } else {
+ glClear(GL_COLOR_BUFFER_BIT);
+ }
}
void gpu_cmd_encoder_end_render(gpu_cmd_encoder* encoder) {
- // glBindFramebuffer(GL_FRAMEBUFFER, 0);
+ glBindFramebuffer(GL_FRAMEBUFFER, 0);
}
void gpu_cmd_encoder_begin_compute() {}
gpu_cmd_encoder* gpu_get_default_cmd_encoder() { return &context.command_buffer; }
@@ -229,11 +238,24 @@ void encode_bind_shader_data(gpu_cmd_encoder* encoder, u32 group, shader_data* d
for (u32 i = 0; i < sdl.bindings_count; i++) {
shader_binding binding = sdl.bindings[i];
- // print_shader_binding(binding);
+ print_shader_binding(binding);
if (binding.type == SHADER_BINDING_BYTES) {
- buffer_handle b = encoder->pipeline->uniform_bindings[i];
- gpu_buffer* ubo_buf = BUFFER_GET(b);
+ buffer_handle b;
+ gpu_buffer* ubo_buf;
+ bool found = false;
+ for (u32 i = 0; i < encoder->pipeline->uniform_count; i++) {
+ b = encoder->pipeline->uniform_bindings[i];
+ ubo_buf = BUFFER_GET(b);
+ assert(ubo_buf->name != NULL);
+ if (strcmp(ubo_buf->name, binding.label) == 0) {
+ found = true;
+ break;
+ }
+ }
+ if (!found) {
+ ERROR("Couldnt find uniform buffer object!!");
+ }
i32 blockIndex = glGetUniformBlockIndex(encoder->pipeline->shader_id, binding.label);
if (blockIndex < 0) {
@@ -247,7 +269,10 @@ void encode_bind_shader_data(gpu_cmd_encoder* encoder, u32 group, shader_data* d
} else if (binding.type == SHADER_BINDING_TEXTURE) {
gpu_texture* tex = TEXTURE_GET(binding.data.texture.handle);
- GLuint tex_slot = glGetUniformLocation(encoder->pipeline->shader_id, binding.label);
+ GLint tex_slot = glGetUniformLocation(encoder->pipeline->shader_id, binding.label);
+ if (tex_slot == GL_INVALID_VALUE || tex_slot < 0) {
+ WARN("Invalid binding label for texture - couldn't fetch texture slot uniform");
+ }
glUniform1i(tex_slot, i);
glActiveTexture(GL_TEXTURE0 + i);
glBindTexture(GL_TEXTURE_2D, tex->id);
@@ -347,13 +372,19 @@ texture_handle gpu_texture_create(texture_desc desc, bool create_view, const voi
GLenum format = desc.format == CEL_TEXTURE_FORMAT_DEPTH_DEFAULT ? GL_DEPTH_COMPONENT : GL_RGBA;
GLenum data_type = desc.format == CEL_TEXTURE_FORMAT_DEPTH_DEFAULT ? GL_FLOAT : GL_UNSIGNED_BYTE;
- // set the texture wrapping parameters
- glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S,
- GL_REPEAT); // set texture wrapping to GL_REPEAT (default wrapping method)
- glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_REPEAT);
- // set texture filtering parameters
- glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR_MIPMAP_LINEAR);
- glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
+ /* // set the texture wrapping parameters */
+ /* glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, */
+ /* GL_REPEAT); // set texture wrapping to GL_REPEAT (default wrapping method) */
+ /* glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_REPEAT); */
+ /* // set texture filtering parameters */
+ /* glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR_MIPMAP_LINEAR); */
+ /* glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR); */
+
+ // TEMP
+ glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST);
+ glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_NEAREST);
+ glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_BORDER);
+ glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_BORDER);
if (data) {
glTexImage2D(GL_TEXTURE_2D, 0, internal_format, desc.extents.x, desc.extents.y, 0, format,
@@ -377,7 +408,10 @@ void gpu_texture_upload(texture_handle texture, const void* data) {}
bytebuffer vertices_as_bytebuffer(arena* a, vertex_format format, vertex_darray* vertices) {}
// --- TEMP
-bool gpu_backend_begin_frame() { return true; }
+bool gpu_backend_begin_frame() {
+ glClearColor(0.1f, 0.1f, 0.1f, 1.0f);
+ glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
+ return true; }
void gpu_backend_end_frame() {
// TODO: Reset all bindings
glfwSwapBuffers(context.window);
diff --git a/src/renderer/backends/opengl/backend_opengl.h b/src/renderer/backends/opengl/backend_opengl.h
index a5a9140..8b88cf8 100644
--- a/src/renderer/backends/opengl/backend_opengl.h
+++ b/src/renderer/backends/opengl/backend_opengl.h
@@ -24,12 +24,12 @@ typedef struct gpu_pipeline {
gpu_renderpass* renderpass;
vertex_description vertex_desc;
buffer_handle uniform_bindings[MAX_PIPELINE_UNIFORM_BUFFERS];
+ u32 uniform_count;
bool wireframe;
} gpu_pipeline;
typedef struct gpu_renderpass {
u32 fbo;
gpu_renderpass_desc description;
- void *pad;
} gpu_renderpass;
typedef struct gpu_cmd_encoder {
gpu_pipeline *pipeline;
@@ -48,6 +48,7 @@ typedef struct gpu_buffer {
u32 vao;
u32 ubo_binding_point
}; // Optional
+ char* name;
u64 size;
} gpu_buffer;
typedef struct gpu_texture {
diff --git a/src/renderer/ral.c b/src/renderer/ral.c
index a52d605..9ca99ce 100644
--- a/src/renderer/ral.c
+++ b/src/renderer/ral.c
@@ -1,8 +1,8 @@
#include "ral.h"
#include "file.h"
#include "log.h"
-#include "str.h"
#include "mem.h"
+#include "str.h"
#if defined(CEL_REND_BACKEND_VULKAN)
#include "backend_vulkan.h"
@@ -88,10 +88,10 @@ shader_desc shader_quick_load(const char* filepath) {
ERROR_EXIT("Failed to load shaders from disk");
}
- return (shader_desc) {
+ return (shader_desc){
.debug_name = filepath,
.code = shader.contents,
.filepath = path,
.is_spirv = true,
};
-} \ No newline at end of file
+}
diff --git a/src/renderer/ral.h b/src/renderer/ral.h
index 9d6ed41..b76de27 100644
--- a/src/renderer/ral.h
+++ b/src/renderer/ral.h
@@ -77,6 +77,8 @@ typedef struct shader_desc {
} shader_desc;
shader_desc shader_quick_load(const char* filepath);
+/** @brief Hot reloads shaders for the given pipeline. Returns how long it took in milliseconds */
+u64 gpu_pipeline_reload_shaders(gpu_pipeline* pipeline); // TODO
struct graphics_pipeline_desc {
const char* debug_name;
diff --git a/src/renderer/render.c b/src/renderer/render.c
index f52e2be..1c98b0b 100644
--- a/src/renderer/render.c
+++ b/src/renderer/render.c
@@ -62,7 +62,7 @@ bool renderer_init(renderer* ren) {
resource_pools_init(&pool_arena, ren->resource_pools);
// Create default rendering pipeline
- default_pipelines_init(ren);
+ /* default_pipelines_init(ren); */
return true;
}
diff --git a/src/renderer/renderpasses.c b/src/renderer/renderpasses.c
index 5193a1c..b93d487 100644
--- a/src/renderer/renderpasses.c
+++ b/src/renderer/renderpasses.c
@@ -25,26 +25,26 @@ shader_data_layout debug_quad_layout(void* data) {
shader_binding b1 = { .label = "depthMap",
.type = SHADER_BINDING_TEXTURE,
- .stores_data = has_data};
+ .stores_data = has_data };
if (has_data) {
b1.data.texture.handle = d->depthMap;
}
- return (shader_data_layout){ .name = "debug quad uniforms", .bindings = { b1 }, .bindings_count = 1 };
+ return (
+ shader_data_layout){ .name = "debug quad uniforms", .bindings = { b1 }, .bindings_count = 1 };
}
gpu_pipeline* debug_quad_pipeline_create() {
- gpu_renderpass_desc rpass_desc = {.default_framebuffer = true };
+ gpu_renderpass_desc rpass_desc = { .default_framebuffer = true };
gpu_renderpass* rpass = gpu_renderpass_create(&rpass_desc);
- shader_data shader_layout = {.data = NULL, .shader_data_get_layout = debug_quad_layout};
- struct graphics_pipeline_desc desc = {
- .debug_name = "Shadow maps debug quad",
- .vertex_desc = static_3d_vertex_description(),
- .data_layouts = { shader_layout },
- .data_layouts_count = 1,
- .vs = shader_quick_load("assets/shaders/debug_quad.vert"),
- .fs = shader_quick_load("assets/shaders/debug_quad.frag"),
- .renderpass = rpass,
- };
+ shader_data shader_layout = { .data = NULL, .shader_data_get_layout = debug_quad_layout };
+ struct graphics_pipeline_desc desc = { .debug_name = "Shadow maps debug quad",
+ .vertex_desc = static_3d_vertex_description(),
+ .data_layouts = { shader_layout },
+ .data_layouts_count = 1,
+ .vs = shader_quick_load("assets/shaders/debug_quad.vert"),
+ .fs = shader_quick_load("assets/shaders/debug_quad.frag"),
+ .renderpass = rpass,
+ .wireframe = false };
return gpu_graphics_pipeline_create(desc);
}
@@ -137,4 +137,4 @@ gpu_pipeline* shadowmaps_pipeline_create(gpu_renderpass* rpass) {
}
void renderpass_shadowmap_execute(gpu_renderpass* pass, render_entity* entities,
- size_t entity_count) {} \ No newline at end of file
+ size_t entity_count) {}