Cycles: Free unused image buffers when rendering with locked interface
It is still possible to free a bit more memory by detecting buildin images which are not used by shaders, but that's not going to improve memory usage that much to bother about this now. Such change brings peak memory usage from 4.1GB to 3.4GB when rendering 01_01_01_D layout scene from the Gooseberry project. Mainly because of freeing memory used by rather huge environment map in the viewport. Reviewers: campbellbarton, juicyfruit Subscribers: eyecandy Differential Revision: https://developer.blender.org/D1215
This commit is contained in:
parent
bb2300de94
commit
74df307ca4
Notes:
blender-bot
2023-04-14 09:18:04 +02:00
Referenced by issue #44662, Freestyle gives no visual output when the Save Buffers option is enabled Referenced by issue #44310, Other render slots cleared after each render Referenced by issue #44132, Crash after open EXR format
|
@ -150,6 +150,7 @@ void BlenderSync::sync_data(BL::SpaceView3D b_v3d, BL::Object b_override, void *
|
|||
sync_integrator();
|
||||
sync_film();
|
||||
sync_shaders();
|
||||
sync_images();
|
||||
sync_curve_settings();
|
||||
|
||||
mesh_synced.clear(); /* use for objects and motion sync */
|
||||
|
@ -360,6 +361,38 @@ void BlenderSync::sync_render_layers(BL::SpaceView3D b_v3d, const char *layer)
|
|||
}
|
||||
}
|
||||
|
||||
/* Images */
|
||||
void BlenderSync::sync_images()
|
||||
{
|
||||
/* Sync is a convention for this API, but currently it frees unused buffers. */
|
||||
|
||||
const bool is_interface_locked = b_engine.render() &&
|
||||
b_engine.render().use_lock_interface();
|
||||
if(is_interface_locked == false && BlenderSession::headless == false) {
|
||||
/* If interface is not locked, it's possible image is needed for
|
||||
* the display.
|
||||
*/
|
||||
return;
|
||||
}
|
||||
/* Free buffers used by images which are not needed for render. */
|
||||
BL::BlendData::images_iterator b_image;
|
||||
for(b_data.images.begin(b_image);
|
||||
b_image != b_data.images.end();
|
||||
++b_image)
|
||||
{
|
||||
/* TODO(sergey): Consider making it an utility function to check
|
||||
* whether image is considered builtin.
|
||||
*/
|
||||
const bool is_builtin = b_image->packed_file() ||
|
||||
b_image->source() == BL::Image::source_GENERATED ||
|
||||
b_image->source() == BL::Image::source_MOVIE;
|
||||
if(is_builtin == false) {
|
||||
b_image->buffers_free();
|
||||
}
|
||||
/* TODO(sergey): Free builtin images not used by any shader. */
|
||||
}
|
||||
}
|
||||
|
||||
/* Scene Parameters */
|
||||
|
||||
SceneParams BlenderSync::get_scene_params(BL::Scene b_scene, bool background, bool is_cpu)
|
||||
|
|
|
@ -95,6 +95,9 @@ private:
|
|||
/* particles */
|
||||
bool sync_dupli_particle(BL::Object b_ob, BL::DupliObject b_dup, Object *object);
|
||||
|
||||
/* Images. */
|
||||
void sync_images();
|
||||
|
||||
/* util */
|
||||
void find_shader(BL::ID id, vector<uint>& used_shaders, int default_shader);
|
||||
bool BKE_object_is_modified(BL::Object b_ob);
|
||||
|
|
|
@ -288,6 +288,11 @@ static void rna_Image_filepath_from_user(Image *image, ImageUser *image_user, ch
|
|||
BKE_image_user_file_path(image_user, image, filepath);
|
||||
}
|
||||
|
||||
static void rna_Image_buffers_free(Image *image)
|
||||
{
|
||||
BKE_image_free_buffers(image);
|
||||
}
|
||||
|
||||
#else
|
||||
|
||||
void RNA_api_image(StructRNA *srna)
|
||||
|
@ -374,6 +379,9 @@ void RNA_api_image(StructRNA *srna)
|
|||
RNA_def_property_flag(parm, PROP_THICK_WRAP); /* needed for string return value */
|
||||
RNA_def_function_output(func, parm);
|
||||
|
||||
func = RNA_def_function(srna, "buffers_free", "rna_Image_buffers_free");
|
||||
RNA_def_function_ui_description(func, "Free the image buffers from memory");
|
||||
|
||||
/* TODO, pack/unpack, maybe should be generic functions? */
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue