diff options
author | Orion Lawlor <lawlor@alaska.edu> | 2024-08-19 18:15:08 -0800 |
---|---|---|
committer | Rémi Verschelde <rverschelde@gmail.com> | 2024-08-20 09:08:16 +0200 |
commit | bde165ccb3dc26c8414ae6e4ab659014d9428ad0 (patch) | |
tree | 084ec72f1702866fbf6aee0967b1d0daa5eee660 /drivers | |
parent | da5f39889f155658cef7f7ec3cc1abb94e17d815 (diff) | |
download | redot-engine-bde165ccb3dc26c8414ae6e4ab659014d9428ad0.tar.gz |
Fix GLES3 crash with Mesh surface with exactly 65536 vertices
Fixes #95837.
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/gles3/storage/mesh_storage.cpp | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/gles3/storage/mesh_storage.cpp b/drivers/gles3/storage/mesh_storage.cpp index d8a5b960b8..89466160c6 100644 --- a/drivers/gles3/storage/mesh_storage.cpp +++ b/drivers/gles3/storage/mesh_storage.cpp @@ -301,7 +301,7 @@ void MeshStorage::mesh_add_surface(RID p_mesh, const RS::SurfaceData &p_surface) Vector<uint8_t> ir = new_surface.index_data; wr = wf_indices.ptrw(); - if (new_surface.vertex_count < (1 << 16)) { + if (new_surface.vertex_count <= 65536) { // Read 16 bit indices. const uint16_t *src_idx = (const uint16_t *)ir.ptr(); for (uint32_t i = 0; i + 5 < wf_index_count; i += 6) { |