From ee1b7fd3bc66501b252ce9e3e5ba89ac9aa54632 Mon Sep 17 00:00:00 2001 From: omniscient <17525998+omnisci3nce@users.noreply.github.com> Date: Sat, 10 Aug 2024 23:18:22 +1000 Subject: more work on bindings and ral --- src/ral/backends/opengl/backend_opengl.c | 11 +++++++++++ src/ral/backends/opengl/opengl_helpers.h | 2 +- src/ral/ral_common.c | 11 ++++++++++- src/ral/ral_common.h | 1 + src/ral/ral_impl.h | 10 +++++++++- src/ral/ral_types.h | 4 ++-- 6 files changed, 34 insertions(+), 5 deletions(-) (limited to 'src/ral') diff --git a/src/ral/backends/opengl/backend_opengl.c b/src/ral/backends/opengl/backend_opengl.c index f971568..6c1a301 100644 --- a/src/ral/backends/opengl/backend_opengl.c +++ b/src/ral/backends/opengl/backend_opengl.c @@ -416,6 +416,17 @@ void GPU_EncodeDrawIndexed(GPU_CmdEncoder* encoder, u64 index_count) { glDrawElements(GL_TRIANGLES, index_count, GL_UNSIGNED_INT, 0); } +PUB void GPU_WriteTextureRegion(GPU_CmdEncoder* encoder, TextureHandle dst, u32 x_offset, + u32 y_offset, u32 width, u32 height, const void* data) { + CASSERT_MSG(data, "const void* data must not be NULL"); + + GPU_Texture* tex = TEXTURE_GET(dst); + + glBindTexture(GL_TEXTURE_2D, tex->id); + glTexSubImage2D(GL_TEXTURE_2D, 0, x_offset, y_offset, width, height, GL_RGBA, GL_UNSIGNED_BYTE, + data); +} + bool GPU_Backend_BeginFrame() { glViewport(0, 0, context.swapchain.dimensions.x * 2, context.swapchain.dimensions.y * 2); glClearColor(0.8f, 0.8f, 0.8f, 1.0f); diff --git a/src/ral/backends/opengl/opengl_helpers.h b/src/ral/backends/opengl/opengl_helpers.h index f240050..0450c74 100644 --- a/src/ral/backends/opengl/opengl_helpers.h +++ b/src/ral/backends/opengl/opengl_helpers.h @@ -59,7 +59,7 @@ static u32 opengl_bindcreate_vao(GPU_Buffer* buf, VertexDescription desc) { u32 attr_count = desc.attributes_count; printf("N attributes %d\n", attr_count); u64 offset = 0; - size_t vertex_size = desc.use_full_vertex_size ? sizeof(Vertex) : desc.stride; + size_t vertex_size = desc.use_full_vertex_size ? sizeof(Vertex) : VertexDesc_CalcStride(&desc); for (u32 i = 0; i < desc.attributes_count; i++) { opengl_vertex_attr format = format_from_vertex_attr(desc.attributes[i]); glVertexAttribPointer(i, format.count, format.data_type, GL_FALSE, vertex_size, (void*)offset); diff --git a/src/ral/ral_common.c b/src/ral/ral_common.c index 35bf15f..53e35f0 100644 --- a/src/ral/ral_common.c +++ b/src/ral/ral_common.c @@ -32,7 +32,7 @@ void VertexDesc_AddAttr(VertexDescription* builder, const char* name, VertexAttr size_t size = VertexAttribSize(type); builder->attributes[i] = type; - builder->stride += size; + // builder->stride += size; builder->attr_names[i] = name; builder->attributes_count++; @@ -59,3 +59,12 @@ size_t VertexAttribSize(VertexAttribType attr) { break; } } + +size_t VertexDesc_CalcStride(VertexDescription* desc) { + size_t stride = 0; + for (int i = 0; i < desc->attributes_count; i++) { + size_t size =VertexAttribSize(desc->attributes[i]); + stride += size; + } + return stride; +} diff --git a/src/ral/ral_common.h b/src/ral/ral_common.h index 8fa09d9..5a797e5 100644 --- a/src/ral/ral_common.h +++ b/src/ral/ral_common.h @@ -56,5 +56,6 @@ void GPU_WindowResizedCallback(u32 x, u32 y); VertexDescription static_3d_vertex_description(); void VertexDesc_AddAttr(VertexDescription* builder, const char* name, VertexAttribType type); +size_t VertexDesc_CalcStride(VertexDescription* desc); size_t VertexAttribSize(VertexAttribType attr); diff --git a/src/ral/ral_impl.h b/src/ral/ral_impl.h index 0ca73c7..f5a16d2 100644 --- a/src/ral/ral_impl.h +++ b/src/ral/ral_impl.h @@ -73,11 +73,19 @@ void copy_buffer_to_image_oneshot(BufferHandle src, TextureHandle dst); // --- Render commands PUB void GPU_EncodeBindPipeline(GPU_CmdEncoder* encoder, GPU_Pipeline* pipeline); -// PUB void GPU_EncodeBindShaderData(GPU_CmdEncoder* encoder, u32 group, ShaderData data); PUB void GPU_EncodeBindShaderData(GPU_CmdEncoder* encoder, u32 group, ShaderDataLayout layout); void GPU_EncodeSetDefaults(GPU_CmdEncoder* encoder); PUB void GPU_EncodeSetVertexBuffer(GPU_CmdEncoder* encoder, BufferHandle buf); PUB void GPU_EncodeSetIndexBuffer(GPU_CmdEncoder* encoder, BufferHandle buf); +PUB void GPU_EncodeCopyBufToBuf(); + +// PUB void GPU_EncodeCopyBufToTex(GPU_CmdEncoder* encoder, BufferHandle src, TextureHandle dst, +// u32 x_offset, u32 y_offset, u32 width, u32 height, const void* data); +/** @brief Convenience method for writing data directly into a texture. Staging memory is handled internally. */ +PUB void GPU_WriteTextureRegion(GPU_CmdEncoder* encoder, TextureHandle dst, + u32 x_offset, u32 y_offset, u32 width, u32 height, const void* data); +PUB void GPU_WriteBuffer(GPU_CmdEncoder* encoder, BufferHandle buf, u64 offset, u64 size, const void* data); + PUB void GPU_EncodeDraw(GPU_CmdEncoder* encoder, u64 count); PUB void GPU_EncodeDrawIndexed(GPU_CmdEncoder* encoder, u64 index_count); PUB void GPU_EncodeDrawInstanced(GPU_CmdEncoder* encoder, u64 index_count, diff --git a/src/ral/ral_types.h b/src/ral/ral_types.h index ec302c1..470e4e9 100644 --- a/src/ral/ral_types.h +++ b/src/ral/ral_types.h @@ -148,11 +148,11 @@ typedef enum VertexAttribType { } VertexAttribType; typedef struct VertexDescription { - char* debug_label; + const char* debug_label; const char* attr_names[MAX_VERTEX_ATTRIBUTES]; VertexAttribType attributes[MAX_VERTEX_ATTRIBUTES]; u32 attributes_count; - size_t stride; + // size_t stride; bool use_full_vertex_size; } VertexDescription; -- cgit v1.2.3-70-g09d2