From 3005c17f626e739b2f8d63f203a0b0a3240eb530 Mon Sep 17 00:00:00 2001 From: Carl Hetherington Date: Sat, 10 Sep 2022 20:14:27 +0200 Subject: [PATCH] Use atomic shared_ptr stuff for _black_frame. --- src/lib/player.cc | 12 ++++++------ src/lib/player.h | 1 + 2 files changed, 7 insertions(+), 6 deletions(-) diff --git a/src/lib/player.cc b/src/lib/player.cc index 9cc7e5d25..0ff2c4032 100644 --- a/src/lib/player.cc +++ b/src/lib/player.cc @@ -344,11 +344,9 @@ Player::set_video_container_size (dcp::Size s) _video_container_size = s; - { - boost::mutex::scoped_lock lm (_mutex); - _black_image = make_shared(AV_PIX_FMT_RGB24, _video_container_size, Image::Alignment::PADDED); - _black_image->make_black (); - } + auto black = make_shared(AV_PIX_FMT_RGB24, _video_container_size, Image::Alignment::PADDED); + black->make_black (); + std::atomic_store(&_black_image, black); Change (ChangeType::DONE, PlayerProperty::VIDEO_CONTAINER_SIZE, false); } @@ -399,8 +397,10 @@ Player::film_change (ChangeType type, Film::Property p) shared_ptr Player::black_player_video_frame (Eyes eyes) const { + auto black = std::atomic_load(&_black_image); + return std::make_shared ( - std::make_shared(_black_image), + std::make_shared(black), Crop(), optional(), _video_container_size, diff --git a/src/lib/player.h b/src/lib/player.h index 388a160c7..5abd59de2 100644 --- a/src/lib/player.h +++ b/src/lib/player.h @@ -173,6 +173,7 @@ private: * the size of preview in a window. */ boost::atomic _video_container_size; + /** Should be accessed using the std::atomic... methods */ std::shared_ptr _black_image; /** true if the player should ignore all video; i.e. never produce any */ -- 2.30.2