summaryrefslogtreecommitdiff
path: root/src/ral/ral_common.c
blob: 8ff282ef09e8a929dee5f07ec96be1cc8493a761 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
#include "ral_common.h"
#include "ral_impl.h"

void BackendPools_Init(arena* a, GPU_BackendPools* backend_pools) {
  PipelineLayout_pool pipeline_layout_pool =
      PipelineLayout_pool_create(a, MAX_PIPELINES, sizeof(GPU_PipelineLayout));
  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;
}

void ResourcePools_Init(arena* a, struct ResourcePools* res_pools) {
  Buffer_pool buf_pool = Buffer_pool_create(a, MAX_BUFFERS, sizeof(GPU_Buffer));
  res_pools->buffers = buf_pool;
  Texture_pool tex_pool = Texture_pool_create(a, MAX_TEXTURES, sizeof(GPU_Texture));
  res_pools->textures = tex_pool;
}

VertexDescription static_3d_vertex_description() {
    VertexDescription builder = { .debug_label = "Standard static 3d vertex format" };
    VertexDesc_AddAttr(&builder, "inPosition", ATTR_F32x3);
    VertexDesc_AddAttr(&builder, "inNormal", ATTR_F32x3);
    VertexDesc_AddAttr(&builder, "inTexCoords", ATTR_F32x2);
    builder.use_full_vertex_size = true;
    return builder;
}

void VertexDesc_AddAttr(VertexDescription* builder, const char* name, VertexAttribType type) {
    u32 i = builder->attributes_count;

    size_t size = VertexAttribSize(type);
    builder->attributes[i] = type;
    builder->stride += size;
    builder->attr_names[i] = name;

    builder->attributes_count++;
}

size_t VertexAttribSize(VertexAttribType attr) {
  switch (attr) {
    case ATTR_F32:
    case ATTR_U32:
    case ATTR_I32:
      return 4;
    case ATTR_F32x2:
    case ATTR_U32x2:
    case ATTR_I32x2:
      return 8;
    case ATTR_F32x3:
    case ATTR_U32x3:
    case ATTR_I32x3:
      return 12;
    case ATTR_F32x4:
    case ATTR_U32x4:
    case ATTR_I32x4:
      return 16;
      break;
  }
}