Fix: Address mobile resource leaks in render
Update render_forward_mobile destructor to include instance buffers. Update render_scene_buffers_rd cleanup to include weight buffers / blur textures.
This commit is contained in:
parent
da945ce626
commit
dfa326ef55
|
@ -2835,6 +2835,11 @@ RenderForwardMobile::~RenderForwardMobile() {
|
|||
for (const RID &rid : scene_state.uniform_buffers) {
|
||||
RD::get_singleton()->free(rid);
|
||||
}
|
||||
for (uint32_t i = 0; i < RENDER_LIST_MAX; i++) {
|
||||
if (scene_state.instance_buffer[i].is_valid()) {
|
||||
RD::get_singleton()->free(scene_state.instance_buffer[i]);
|
||||
}
|
||||
}
|
||||
RD::get_singleton()->free(scene_state.lightmap_buffer);
|
||||
RD::get_singleton()->free(scene_state.lightmap_capture_buffer);
|
||||
memdelete_arr(scene_state.lightmap_captures);
|
||||
|
|
|
@ -128,6 +128,13 @@ void RenderSceneBuffersRD::cleanup() {
|
|||
free_named_texture(E.value);
|
||||
}
|
||||
named_textures.clear();
|
||||
|
||||
// Clear weight_buffer / blur textures.
|
||||
for (const WeightBuffers &weight_buffer : weight_buffers) {
|
||||
if (weight_buffer.weight.is_valid()) {
|
||||
RD::get_singleton()->free(weight_buffer.weight);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void RenderSceneBuffersRD::configure(const RenderSceneBuffersConfiguration *p_config) {
|
||||
|
|
Loading…
Reference in New Issue