summaryrefslogtreecommitdiff
path: root/src/renderer/backends/opengl/backend_opengl.c
diff options
context:
space:
mode:
authorOmniscient <omniscient.oce@gmail.com>2024-06-07 12:10:53 +1000
committerOmniscient <omniscient.oce@gmail.com>2024-06-07 12:10:53 +1000
commit4976c723a7add3a1409eb529d088868a2c568fbb (patch)
tree1ca0f1fb33cb97d79722cae5b5571653b9e1689b /src/renderer/backends/opengl/backend_opengl.c
parentf553d66891e6f77b0fa78c279f51a44d1c51ff9f (diff)
add vertex/index buffer binding in opengl
Diffstat (limited to 'src/renderer/backends/opengl/backend_opengl.c')
-rw-r--r--src/renderer/backends/opengl/backend_opengl.c29
1 files changed, 19 insertions, 10 deletions
diff --git a/src/renderer/backends/opengl/backend_opengl.c b/src/renderer/backends/opengl/backend_opengl.c
index a933462..cb25b46 100644
--- a/src/renderer/backends/opengl/backend_opengl.c
+++ b/src/renderer/backends/opengl/backend_opengl.c
@@ -18,7 +18,9 @@
typedef struct opengl_context {
GLFWwindow* window;
arena pool_arena;
+ gpu_cmd_encoder command_buffer;
gpu_backend_pools gpu_pools;
+ struct resource_pools* resource_pools;
} opengl_context;
static opengl_context context;
@@ -35,13 +37,15 @@ bool gpu_backend_init(const char* window_name, struct GLFWwindow* window) {
context.pool_arena = arena_create(malloc(pool_buffer_size), pool_buffer_size);
backend_pools_init(&context.pool_arena, &context.gpu_pools);
+ context.resource_pools = malloc(sizeof(struct resource_pools));
+ resource_pools_init(&context.pool_arena, context.resource_pools);
glfwWindowHint(GLFW_CONTEXT_VERSION_MAJOR, 4);
- glfwWindowHint(GLFW_CONTEXT_VERSION_MINOR, 1);
+ glfwWindowHint(GLFW_CONTEXT_VERSION_MINOR, 3);
glfwWindowHint(GLFW_OPENGL_PROFILE, GLFW_OPENGL_CORE_PROFILE);
glfwWindowHint(GLFW_OPENGL_FORWARD_COMPAT, GL_TRUE);
- // glad: load all OpenGL function pointers
+ // glad: load all opengl function pointers
if (!gladLoadGLLoader((GLADloadproc)glfwGetProcAddress)) {
ERROR("Failed to initialise GLAD \n");
return false;
@@ -53,7 +57,6 @@ bool gpu_backend_init(const char* window_name, struct GLFWwindow* window) {
}
void gpu_backend_shutdown() {}
-void resource_pools_init(arena* a, struct resource_pools* res_pools) {}
bool gpu_device_create(gpu_device* out_device) {}
void gpu_device_destroy() {}
@@ -102,7 +105,9 @@ void gpu_cmd_encoder_begin_render(gpu_cmd_encoder* encoder, gpu_renderpass* rend
}
void gpu_cmd_encoder_end_render(gpu_cmd_encoder* encoder) {}
void gpu_cmd_encoder_begin_compute() {}
-gpu_cmd_encoder* gpu_get_default_cmd_encoder() {}
+gpu_cmd_encoder* gpu_get_default_cmd_encoder() {
+ return &context.command_buffer;
+}
/** @brief Finish recording and return a command buffer that can be submitted to a queue */
gpu_cmd_buffer gpu_cmd_encoder_finish(gpu_cmd_encoder* encoder) {}
@@ -152,19 +157,23 @@ buffer_handle gpu_buffer_create(u64 size, gpu_buffer_type buf_type, gpu_buffer_f
switch (buf_type) {
case CEL_BUFFER_UNIFORM:
glBindBuffer(GL_UNIFORM_BUFFER, gl_buffer_id);
+ break;
case CEL_BUFFER_DEFAULT:
case CEL_BUFFER_VERTEX:
+ glBindBuffer(GL_ARRAY_BUFFER, gl_buffer_id);
+ break;
case CEL_BUFFER_INDEX:
- WARN("Unimplemented gpu_buffer_type!");
+ glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, gl_buffer_id);
break;
- case CEL_BUFFER_COUNT:
- WARN("Incorrect gpu_buffer_type provided.");
+ default:
+ WARN("Unimplemented gpu_buffer_type provided %s", buffer_type_names[buf_type]);
break;
}
buffer_handle handle;
- gpu_buffer* buffer = buffer_pool_alloc(&context.resource_pools, &handle);
-
+ gpu_buffer* buffer = buffer_pool_alloc(&context.resource_pools->buffers, &handle);
+
+ return handle;
}
void gpu_buffer_destroy(buffer_handle buffer) {}
@@ -395,4 +404,4 @@ void uniform_mat4f(u32 program_id, const char *uniform_name, mat4 *value) {
// void set_shader(shader s) { glUseProgram(s.program_id); }
-#endif \ No newline at end of file
+#endif