Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Primitive storage and static model improvements #171

Closed
wants to merge 46 commits into from
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
46 commits
Select commit Hold shift + click to select a range
d28f882
Replaced the SoA storage of world and instanced primitives with unifi…
apanteleev Nov 25, 2021
0d6d22b
Fixed the tangents upload code.
apanteleev Nov 25, 2021
2b19383
Switched to writing the primitive data in bsp_mesh directly. Massive …
apanteleev Nov 25, 2021
9d1e47c
Switched the data formats for frame-based and IQM models to the same …
apanteleev Dec 9, 2021
318e641
Removed the sky and dynamic flags from ray payload, added buffer index.
apanteleev Dec 10, 2021
02e2a56
Replaced the single instanceCustomIndex field storing a dynamic flag …
apanteleev Dec 11, 2021
9b652f9
Break up long line (no functional changes).
apanteleev Dec 11, 2021
6b358e6
Build static BLAS for models without animations.
apanteleev Dec 11, 2021
d6bf89a
Replaced the macro-driven declaration of instance buffer structure co…
apanteleev Dec 13, 2021
0eaa588
Fixed the flickering lights on bsp models.
apanteleev Dec 13, 2021
87fc76f
Use static BLAS of eligible models instead of passing them through in…
apanteleev Dec 13, 2021
cc60f1d
Unified the BSP models and regular models into the same representatio…
apanteleev Dec 14, 2021
38ec7ed
Added support for multiple meshes/geometries in static models.
apanteleev Dec 15, 2021
d2b944c
Switched from a statically sized world primitive buffer to a dynamic …
apanteleev Dec 15, 2021
73bf198
Place the world BLAS into the same vertex buffer, create BLAS for BSP…
apanteleev Dec 16, 2021
82d9ac2
Removed the MAX_MODEL_MESHES limit.
apanteleev Dec 16, 2021
b814ed6
Added calculation of model tangents on load.
apanteleev Dec 16, 2021
a41502f
Removed a stale comment.
apanteleev Dec 16, 2021
bba1bb5
Implemented shadow map rendering for instanced static meshes - both b…
apanteleev Dec 16, 2021
1ded7f7
Refactoring the fill_model_instance function.
apanteleev Dec 16, 2021
c2ada48
That was unnecessary.
apanteleev Dec 16, 2021
66e75a1
Disabled culling on transparent materials.
apanteleev Dec 16, 2021
a5e136c
Removed the unnecessary use_prim_offset parameter.
apanteleev Dec 16, 2021
5f0cab4
Increased the max instance count.
apanteleev Dec 16, 2021
29b16eb
Track primitives, not vertices.
apanteleev Dec 17, 2021
4b25324
Replaced MAX_PRIM_INSTANCED with a dynamically sized buffer.
apanteleev Dec 17, 2021
01b314d
Added the missing VERTEX_BUFFER bit to the model VBOs.
apanteleev Dec 17, 2021
58bad6d
Clang compat and cleanup.
apanteleev Dec 18, 2021
e3bcb45
Fixed the masked materials on static models.
apanteleev Dec 18, 2021
25b232d
Re-create the static model VBOs when their materials change.
apanteleev Dec 18, 2021
6404801
Renamed the motion fields in VboPrimitive for clarity.
apanteleev Dec 18, 2021
835de32
Expanded the V-buffer to have enough bits for many instances with mil…
apanteleev Dec 18, 2021
4746ce7
Merge branch 'master' into vbo
apanteleev Dec 18, 2021
21c7277
Addressing PR feedback.
apanteleev Dec 18, 2021
74c3c60
Replaced the uses of mat3 for positions of a triangle with prim_posit…
apanteleev Dec 18, 2021
762d608
Rollback the TRIANGLE_FACING_CULL_DISABLE_BIT change on transparent g…
apanteleev Dec 18, 2021
5944201
Merge branch 'master' into vbo
apanteleev Dec 18, 2021
a34e8c9
Merge branch 'master' into vbo
apanteleev Dec 20, 2021
03972d6
Fixed the model resource leaks on map change.
apanteleev Dec 20, 2021
0ae6d78
Fixed the BSP resource leak on map change.
apanteleev Dec 20, 2021
57e2a49
Added debug names to model and world objects.
apanteleev Dec 20, 2021
ed2ad93
Fixed the excessive destruction of model VBOs on map or material chan…
apanteleev Dec 20, 2021
cb04989
Fixed the memory leak in the static environment maps on map changes.
apanteleev Dec 20, 2021
a161674
Fixed the primitive indexing for explosions.
apanteleev Dec 20, 2021
e1b2a22
Added support for generic translucent geometry specified using the SU…
apanteleev Dec 20, 2021
53a5af3
Fixed the player setup screen rendering.
apanteleev Dec 20, 2021
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 0 additions & 1 deletion cmake/compileShaders.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,6 @@ set(SHADER_SOURCE_DEPENDENCIES
${CMAKE_SOURCE_DIR}/src/refresh/vkpt/shader/precomputed_sky.glsl
${CMAKE_SOURCE_DIR}/src/refresh/vkpt/shader/precomputed_sky_params.h
${CMAKE_SOURCE_DIR}/src/refresh/vkpt/shader/projection.glsl
${CMAKE_SOURCE_DIR}/src/refresh/vkpt/shader/read_visbuf.glsl
${CMAKE_SOURCE_DIR}/src/refresh/vkpt/shader/sky.h
${CMAKE_SOURCE_DIR}/src/refresh/vkpt/shader/tiny_encryption_algorithm.h
${CMAKE_SOURCE_DIR}/src/refresh/vkpt/shader/tone_mapping_utils.glsl
Expand Down
2 changes: 1 addition & 1 deletion inc/common/bsp.h
Original file line number Diff line number Diff line change
Expand Up @@ -308,7 +308,7 @@ void BSP_TransformedLightPoint(lightpoint_t *point, vec3_t start, vec3_t end,
#endif

byte *BSP_ClusterVis(bsp_t *bsp, byte *mask, int cluster, int vis);
mleaf_t *BSP_PointLeaf(mnode_t *node, vec3_t p);
mleaf_t *BSP_PointLeaf(mnode_t *node, const vec3_t p);
mmodel_t *BSP_InlineModel(bsp_t *bsp, const char *name);

byte* BSP_GetPvs(bsp_t *bsp, int cluster);
Expand Down
2 changes: 1 addition & 1 deletion inc/common/math.h
Original file line number Diff line number Diff line change
Expand Up @@ -54,7 +54,7 @@ static inline int BoxOnPlaneSideFast(vec3_t emins, vec3_t emaxs, cplane_t *p)
return BoxOnPlaneSide(emins, emaxs, p);
}

static inline vec_t PlaneDiffFast(vec3_t v, cplane_t *p)
static inline vec_t PlaneDiffFast(const vec3_t v, cplane_t *p)
{
// fast axial cases
if (p->type < 3) {
Expand Down
2 changes: 1 addition & 1 deletion inc/refresh/models.h
Original file line number Diff line number Diff line change
Expand Up @@ -86,7 +86,7 @@ typedef struct
float* tangents;
byte* colors;
byte* blend_indices; // byte4 per vertex
float* blend_weights; // float4 per vertex
byte* blend_weights; // byte4 per vertex

char* jointNames;
int* jointParents;
Expand Down
2 changes: 1 addition & 1 deletion src/common/bsp.c
Original file line number Diff line number Diff line change
Expand Up @@ -1922,7 +1922,7 @@ byte *BSP_ClusterVis(bsp_t *bsp, byte *mask, int cluster, int vis)
return mask;
}

mleaf_t *BSP_PointLeaf(mnode_t *node, vec3_t p)
mleaf_t *BSP_PointLeaf(mnode_t *node, const vec3_t p)
{
float d;

Expand Down
55 changes: 32 additions & 23 deletions src/refresh/model_iqm.c
Original file line number Diff line number Diff line change
Expand Up @@ -446,7 +446,7 @@ int MOD_LoadIQM_Base(model_t* model, const void* rawdata, size_t length, const c
}
}

CHECK(iqmData = (iqm_model_t*)MOD_Malloc(sizeof(iqm_model_t)));
CHECK(iqmData = MOD_Malloc(sizeof(iqm_model_t)));
model->iqmData = iqmData;

// fill header
Expand All @@ -459,20 +459,20 @@ int MOD_LoadIQM_Base(model_t* model, const void* rawdata, size_t length, const c

if (header->num_meshes)
{
CHECK(iqmData->meshes = (iqm_mesh_t*)MOD_Malloc(header->num_meshes * sizeof(iqm_mesh_t)));
CHECK(iqmData->indices = (uint32_t*)MOD_Malloc(header->num_triangles * 3 * sizeof(int)));
CHECK(iqmData->positions = (float*)MOD_Malloc(header->num_vertexes * 3 * sizeof(float)));
CHECK(iqmData->texcoords = (float*)MOD_Malloc(header->num_vertexes * 2 * sizeof(float)));
CHECK(iqmData->normals = (float*)MOD_Malloc(header->num_vertexes * 3 * sizeof(float)));
CHECK(iqmData->meshes = MOD_Malloc(header->num_meshes * sizeof(iqm_mesh_t)));
CHECK(iqmData->indices = MOD_Malloc(header->num_triangles * 3 * sizeof(int)));
CHECK(iqmData->positions = MOD_Malloc(header->num_vertexes * 3 * sizeof(float)));
CHECK(iqmData->texcoords = MOD_Malloc(header->num_vertexes * 2 * sizeof(float)));
CHECK(iqmData->normals = MOD_Malloc(header->num_vertexes * 3 * sizeof(float)));

if (vertexArrayFormat[IQM_TANGENT] != -1)
{
CHECK(iqmData->tangents = (float*)MOD_Malloc(header->num_vertexes * 4 * sizeof(float)));
CHECK(iqmData->tangents = MOD_Malloc(header->num_vertexes * 4 * sizeof(float)));
}

if (vertexArrayFormat[IQM_COLOR] != -1)
{
CHECK(iqmData->colors = (byte*)MOD_Malloc(header->num_vertexes * 4 * sizeof(byte)));
CHECK(iqmData->colors = MOD_Malloc(header->num_vertexes * 4 * sizeof(byte)));
}

if (vertexArrayFormat[IQM_BLENDINDEXES] != -1)
Expand All @@ -482,30 +482,30 @@ int MOD_LoadIQM_Base(model_t* model, const void* rawdata, size_t length, const c

if (vertexArrayFormat[IQM_BLENDWEIGHTS] != -1)
{
CHECK(iqmData->blend_weights = (float*)MOD_Malloc(header->num_vertexes * 4 * sizeof(float)));
CHECK(iqmData->blend_weights = MOD_Malloc(header->num_vertexes * 4 * sizeof(byte)));
}
}

if (header->num_joints)
{
CHECK(iqmData->jointNames = (char*)MOD_Malloc(joint_names));
CHECK(iqmData->jointParents = (int*)MOD_Malloc(header->num_joints * sizeof(int)));
CHECK(iqmData->bindJoints = (float*)MOD_Malloc(header->num_joints * 12 * sizeof(float))); // bind joint matricies
CHECK(iqmData->invBindJoints = (float*)MOD_Malloc(header->num_joints * 12 * sizeof(float))); // inverse bind joint matricies
CHECK(iqmData->jointNames = MOD_Malloc(joint_names));
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

this just reminded me, on my local branch I changed jointNames to be an array of char[MAX_QPATH] so that I can easily index the joint names at runtime. Currently, you need to loop over the string via strlen which is pretty inefficient.. not that it totally matters I guess since you shouldn't be looping through joint names every frame at runtime, but just a random note that I think a single long string of "name data" is a bit harder to parse through than just fixed-length string indices.

CHECK(iqmData->jointParents = MOD_Malloc(header->num_joints * sizeof(int)));
CHECK(iqmData->bindJoints = MOD_Malloc(header->num_joints * 12 * sizeof(float))); // bind joint matricies
CHECK(iqmData->invBindJoints = MOD_Malloc(header->num_joints * 12 * sizeof(float))); // inverse bind joint matricies
}

if (header->num_poses)
{
CHECK(iqmData->poses = (iqm_transform_t*)MOD_Malloc(header->num_poses * header->num_frames * sizeof(iqm_transform_t))); // pose transforms
CHECK(iqmData->poses = MOD_Malloc(header->num_poses * header->num_frames * sizeof(iqm_transform_t))); // pose transforms
}

if (header->ofs_bounds)
{
CHECK(iqmData->bounds = (float*)MOD_Malloc(header->num_frames * 6 * sizeof(float))); // model bounds
CHECK(iqmData->bounds = MOD_Malloc(header->num_frames * 6 * sizeof(float))); // model bounds
}
else if (header->num_meshes && header->num_frames == 0)
{
CHECK(iqmData->bounds = (float*)MOD_Malloc(6 * sizeof(float))); // model bounds
CHECK(iqmData->bounds = MOD_Malloc(6 * sizeof(float))); // model bounds
}

if (header->num_meshes)
Expand Down Expand Up @@ -575,20 +575,29 @@ int MOD_LoadIQM_Base(model_t* model, const void* rawdata, size_t length, const c
n * sizeof(float));
break;
case IQM_BLENDWEIGHTS:
if (vertexArrayFormat[IQM_BLENDWEIGHTS] == IQM_FLOAT)
if (vertexArrayFormat[IQM_BLENDWEIGHTS] == IQM_UBYTE)
{
memcpy(iqmData->blend_weights,
(const byte*)header + vertexarray->offset,
n * sizeof(float));
n * sizeof(byte));
}
else
else if(vertexArrayFormat[IQM_BLENDWEIGHTS] == IQM_FLOAT)
{
// convert blend weights from byte to float
for (uint32_t vertex_idx = 0; vertex_idx < 4 * header->num_vertexes; vertex_idx++)
const float* weights = (const float*)((const byte*)header + vertexarray->offset);

// convert blend weights from float to byte
for (uint32_t weight_idx = 0; weight_idx < 4 * header->num_vertexes; weight_idx++)
{
iqmData->blend_weights[vertex_idx] = (float)((const byte*)header + vertexarray->offset)[vertex_idx] / 255.f;
float integer_weight = weights[weight_idx] * 255.f;
clamp(integer_weight, 0.f, 255.f);
iqmData->blend_weights[weight_idx] = (byte)integer_weight;
}
}
else
{
Com_WPrintf("R_LoadIQM: unsupported format for blend weights (%d)\n", vertexArrayFormat[IQM_BLENDWEIGHTS]);
memset(iqmData->blend_weights, 0, n * sizeof(byte));
}
break;
case IQM_COLOR:
memcpy(iqmData->colors,
Expand Down Expand Up @@ -718,7 +727,7 @@ int MOD_LoadIQM_Base(model_t* model, const void* rawdata, size_t length, const c
if (header->num_anims)
{
iqmData->num_animations = header->num_anims;
CHECK(iqmData->animations = (iqm_anim_t*)MOD_Malloc(header->num_anims * sizeof(iqm_anim_t)));
CHECK(iqmData->animations = MOD_Malloc(header->num_anims * sizeof(iqm_anim_t)));

const iqmAnim_t* src = (const iqmAnim_t*)((const byte*)header + header->ofs_anims);
iqm_anim_t* dst = iqmData->animations;
Expand Down
Loading