[libcamera-devel] [PATCH 1/7] ipa: raspberrypi: Use libcamera Mutex class

Hirokazu Honda hiroh at chromium.org
Fri Dec 3 20:55:33 CET 2021


This replaces std::mutex, std::unique_lock and
std::condition_variable in src/ipa/raspberrypi with libcamera
Mutex, MutexLocker and ConditionVariable, respectively.

Signed-off-by: Hirokazu Honda <hiroh at chromium.org>
---
 src/ipa/raspberrypi/controller/metadata.hpp   | 28 +++++++++++--------
 src/ipa/raspberrypi/controller/rpi/alsc.cpp   | 12 ++++----
 src/ipa/raspberrypi/controller/rpi/alsc.hpp   | 10 +++----
 src/ipa/raspberrypi/controller/rpi/awb.cpp    | 10 +++----
 src/ipa/raspberrypi/controller/rpi/awb.hpp    | 10 +++----
 .../raspberrypi/controller/rpi/contrast.cpp   |  4 +--
 .../raspberrypi/controller/rpi/contrast.hpp   |  4 +--
 src/ipa/raspberrypi/controller/rpi/lux.cpp    |  4 +--
 src/ipa/raspberrypi/controller/rpi/lux.hpp    |  5 ++--
 9 files changed, 45 insertions(+), 42 deletions(-)

diff --git a/src/ipa/raspberrypi/controller/metadata.hpp b/src/ipa/raspberrypi/controller/metadata.hpp
index 51e576cf..ff2e1ae3 100644
--- a/src/ipa/raspberrypi/controller/metadata.hpp
+++ b/src/ipa/raspberrypi/controller/metadata.hpp
@@ -10,9 +10,10 @@
 
 #include <any>
 #include <map>
-#include <mutex>
 #include <string>
 
+#include <libcamera/base/mutex.h>
+
 namespace RPiController {
 
 class Metadata
@@ -22,13 +23,13 @@ public:
 
 	Metadata(Metadata const &other)
 	{
-		std::scoped_lock other_lock(other.mutex_);
+		libcamera::MutexLocker other_lock(other.mutex_);
 		data_ = other.data_;
 	}
 
 	Metadata(Metadata &&other)
 	{
-		std::scoped_lock other_lock(other.mutex_);
+		libcamera::MutexLocker other_lock(other.mutex_);
 		data_ = std::move(other.data_);
 		other.data_.clear();
 	}
@@ -36,14 +37,14 @@ public:
 	template<typename T>
 	void Set(std::string const &tag, T const &value)
 	{
-		std::scoped_lock lock(mutex_);
+		libcamera::MutexLocker lock(mutex_);
 		data_[tag] = value;
 	}
 
 	template<typename T>
 	int Get(std::string const &tag, T &value) const
 	{
-		std::scoped_lock lock(mutex_);
+		libcamera::MutexLocker lock(mutex_);
 		auto it = data_.find(tag);
 		if (it == data_.end())
 			return -1;
@@ -53,20 +54,22 @@ public:
 
 	void Clear()
 	{
-		std::scoped_lock lock(mutex_);
+		libcamera::MutexLocker lock(mutex_);
 		data_.clear();
 	}
 
 	Metadata &operator=(Metadata const &other)
 	{
-		std::scoped_lock lock(mutex_, other.mutex_);
+		libcamera::MutexLocker lock(mutex_);
+		libcamera::MutexLocker other_lock(other.mutex_);
 		data_ = other.data_;
 		return *this;
 	}
 
 	Metadata &operator=(Metadata &&other)
 	{
-		std::scoped_lock lock(mutex_, other.mutex_);
+		libcamera::MutexLocker lock(mutex_);
+		libcamera::MutexLocker other_lock(other.mutex_);
 		data_ = std::move(other.data_);
 		other.data_.clear();
 		return *this;
@@ -74,7 +77,8 @@ public:
 
 	void Merge(Metadata &other)
 	{
-		std::scoped_lock lock(mutex_, other.mutex_);
+		libcamera::MutexLocker lock(mutex_);
+		libcamera::MutexLocker other_lock(other.mutex_);
 		data_.merge(other.data_);
 	}
 
@@ -99,11 +103,11 @@ public:
 	// Note: use of (lowercase) lock and unlock means you can create scoped
 	// locks with the standard lock classes.
 	// e.g. std::lock_guard<RPiController::Metadata> lock(metadata)
-	void lock() { mutex_.lock(); }
-	void unlock() { mutex_.unlock(); }
+	void lock() LIBCAMERA_TSA_ACQUIRE(mutex_) { mutex_.lock(); }
+	void unlock() LIBCAMERA_TSA_RELEASE(mutex_) { mutex_.unlock(); }
 
 private:
-	mutable std::mutex mutex_;
+	mutable libcamera::Mutex mutex_;
 	std::map<std::string, std::any> data_;
 };
 
diff --git a/src/ipa/raspberrypi/controller/rpi/alsc.cpp b/src/ipa/raspberrypi/controller/rpi/alsc.cpp
index be3d1ae4..97a05a30 100644
--- a/src/ipa/raspberrypi/controller/rpi/alsc.cpp
+++ b/src/ipa/raspberrypi/controller/rpi/alsc.cpp
@@ -35,7 +35,7 @@ Alsc::Alsc(Controller *controller)
 Alsc::~Alsc()
 {
 	{
-		std::lock_guard<std::mutex> lock(mutex_);
+		MutexLocker lock(mutex_);
 		async_abort_ = true;
 	}
 	async_signal_.notify_one();
@@ -179,7 +179,7 @@ void Alsc::waitForAysncThread()
 {
 	if (async_started_) {
 		async_started_ = false;
-		std::unique_lock<std::mutex> lock(mutex_);
+		MutexLocker lock(mutex_);
 		sync_signal_.wait(lock, [&] {
 			return async_finished_;
 		});
@@ -314,7 +314,7 @@ void Alsc::restartAsync(StatisticsPtr &stats, Metadata *image_metadata)
 	frame_phase_ = 0;
 	async_started_ = true;
 	{
-		std::lock_guard<std::mutex> lock(mutex_);
+		MutexLocker lock(mutex_);
 		async_start_ = true;
 	}
 	async_signal_.notify_one();
@@ -332,7 +332,7 @@ void Alsc::Prepare(Metadata *image_metadata)
 	LOG(RPiAlsc, Debug)
 		<< "frame_count " << frame_count_ << " speed " << speed;
 	{
-		std::unique_lock<std::mutex> lock(mutex_);
+		MutexLocker lock(mutex_);
 		if (async_started_ && async_finished_)
 			fetchAsyncResults();
 	}
@@ -370,7 +370,7 @@ void Alsc::asyncFunc()
 {
 	while (true) {
 		{
-			std::unique_lock<std::mutex> lock(mutex_);
+			MutexLocker lock(mutex_);
 			async_signal_.wait(lock, [&] {
 				return async_start_ || async_abort_;
 			});
@@ -380,7 +380,7 @@ void Alsc::asyncFunc()
 		}
 		doAlsc();
 		{
-			std::lock_guard<std::mutex> lock(mutex_);
+			MutexLocker lock(mutex_);
 			async_finished_ = true;
 		}
 		sync_signal_.notify_one();
diff --git a/src/ipa/raspberrypi/controller/rpi/alsc.hpp b/src/ipa/raspberrypi/controller/rpi/alsc.hpp
index 9616b99e..3f9d6837 100644
--- a/src/ipa/raspberrypi/controller/rpi/alsc.hpp
+++ b/src/ipa/raspberrypi/controller/rpi/alsc.hpp
@@ -6,10 +6,10 @@
  */
 #pragma once
 
-#include <mutex>
-#include <condition_variable>
 #include <thread>
 
+#include <libcamera/base/mutex.h>
+
 #include "../algorithm.hpp"
 #include "../alsc_status.h"
 
@@ -63,11 +63,11 @@ private:
 	double luminance_table_[ALSC_CELLS_X * ALSC_CELLS_Y];
 	std::thread async_thread_;
 	void asyncFunc(); // asynchronous thread function
-	std::mutex mutex_;
+	libcamera::Mutex mutex_;
 	// condvar for async thread to wait on
-	std::condition_variable async_signal_;
+	libcamera::ConditionVariable async_signal_;
 	// condvar for synchronous thread to wait on
-	std::condition_variable sync_signal_;
+	libcamera::ConditionVariable sync_signal_;
 	// for sync thread to check  if async thread finished (requires mutex)
 	bool async_finished_;
 	// for async thread to check if it's been told to run (requires mutex)
diff --git a/src/ipa/raspberrypi/controller/rpi/awb.cpp b/src/ipa/raspberrypi/controller/rpi/awb.cpp
index 5cfd33a3..b4e45abf 100644
--- a/src/ipa/raspberrypi/controller/rpi/awb.cpp
+++ b/src/ipa/raspberrypi/controller/rpi/awb.cpp
@@ -132,7 +132,7 @@ Awb::Awb(Controller *controller)
 Awb::~Awb()
 {
 	{
-		std::lock_guard<std::mutex> lock(mutex_);
+		MutexLocker lock(mutex_);
 		async_abort_ = true;
 	}
 	async_signal_.notify_one();
@@ -252,7 +252,7 @@ void Awb::restartAsync(StatisticsPtr &stats, double lux)
 				     sizeof(async_results_.mode) - 1);
 	async_results_.mode[len] = '\0';
 	{
-		std::lock_guard<std::mutex> lock(mutex_);
+		MutexLocker lock(mutex_);
 		async_start_ = true;
 	}
 	async_signal_.notify_one();
@@ -268,7 +268,7 @@ void Awb::Prepare(Metadata *image_metadata)
 	LOG(RPiAwb, Debug)
 		<< "frame_count " << frame_count_ << " speed " << speed;
 	{
-		std::unique_lock<std::mutex> lock(mutex_);
+		MutexLocker lock(mutex_);
 		if (async_started_ && async_finished_)
 			fetchAsyncResults();
 	}
@@ -317,7 +317,7 @@ void Awb::asyncFunc()
 {
 	while (true) {
 		{
-			std::unique_lock<std::mutex> lock(mutex_);
+			MutexLocker lock(mutex_);
 			async_signal_.wait(lock, [&] {
 				return async_start_ || async_abort_;
 			});
@@ -327,7 +327,7 @@ void Awb::asyncFunc()
 		}
 		doAwb();
 		{
-			std::lock_guard<std::mutex> lock(mutex_);
+			MutexLocker lock(mutex_);
 			async_finished_ = true;
 		}
 		sync_signal_.notify_one();
diff --git a/src/ipa/raspberrypi/controller/rpi/awb.hpp b/src/ipa/raspberrypi/controller/rpi/awb.hpp
index 8af1f27c..30f39c4a 100644
--- a/src/ipa/raspberrypi/controller/rpi/awb.hpp
+++ b/src/ipa/raspberrypi/controller/rpi/awb.hpp
@@ -6,10 +6,10 @@
  */
 #pragma once
 
-#include <mutex>
-#include <condition_variable>
 #include <thread>
 
+#include <libcamera/base/mutex.h>
+
 #include "../awb_algorithm.hpp"
 #include "../pwl.hpp"
 #include "../awb_status.h"
@@ -108,11 +108,11 @@ private:
 	AwbConfig config_;
 	std::thread async_thread_;
 	void asyncFunc(); // asynchronous thread function
-	std::mutex mutex_;
+	libcamera::Mutex mutex_;
 	// condvar for async thread to wait on
-	std::condition_variable async_signal_;
+	libcamera::ConditionVariable async_signal_;
 	// condvar for synchronous thread to wait on
-	std::condition_variable sync_signal_;
+	libcamera::ConditionVariable sync_signal_;
 	// for sync thread to check  if async thread finished (requires mutex)
 	bool async_finished_;
 	// for async thread to check if it's been told to run (requires mutex)
diff --git a/src/ipa/raspberrypi/controller/rpi/contrast.cpp b/src/ipa/raspberrypi/controller/rpi/contrast.cpp
index ae55aad5..6726b4e3 100644
--- a/src/ipa/raspberrypi/controller/rpi/contrast.cpp
+++ b/src/ipa/raspberrypi/controller/rpi/contrast.cpp
@@ -88,7 +88,7 @@ void Contrast::Initialise()
 
 void Contrast::Prepare(Metadata *image_metadata)
 {
-	std::unique_lock<std::mutex> lock(mutex_);
+	MutexLocker lock(mutex_);
 	image_metadata->Set("contrast.status", status_);
 }
 
@@ -172,7 +172,7 @@ void Contrast::Process(StatisticsPtr &stats,
 	ContrastStatus status;
 	fill_in_status(status, brightness_, contrast_, gamma_curve);
 	{
-		std::unique_lock<std::mutex> lock(mutex_);
+		MutexLocker lock(mutex_);
 		status_ = status;
 	}
 }
diff --git a/src/ipa/raspberrypi/controller/rpi/contrast.hpp b/src/ipa/raspberrypi/controller/rpi/contrast.hpp
index 85624539..b74e06ab 100644
--- a/src/ipa/raspberrypi/controller/rpi/contrast.hpp
+++ b/src/ipa/raspberrypi/controller/rpi/contrast.hpp
@@ -6,7 +6,7 @@
  */
 #pragma once
 
-#include <mutex>
+#include <libcamera/base/mutex.h>
 
 #include "../contrast_algorithm.hpp"
 #include "../pwl.hpp"
@@ -44,7 +44,7 @@ private:
 	double brightness_;
 	double contrast_;
 	ContrastStatus status_;
-	std::mutex mutex_;
+	libcamera::Mutex mutex_;
 };
 
 } // namespace RPiController
diff --git a/src/ipa/raspberrypi/controller/rpi/lux.cpp b/src/ipa/raspberrypi/controller/rpi/lux.cpp
index f77e9140..7198f64b 100644
--- a/src/ipa/raspberrypi/controller/rpi/lux.cpp
+++ b/src/ipa/raspberrypi/controller/rpi/lux.cpp
@@ -54,7 +54,7 @@ void Lux::SetCurrentAperture(double aperture)
 
 void Lux::Prepare(Metadata *image_metadata)
 {
-	std::unique_lock<std::mutex> lock(mutex_);
+	MutexLocker lock(mutex_);
 	image_metadata->Set("lux.status", status_);
 }
 
@@ -88,7 +88,7 @@ void Lux::Process(StatisticsPtr &stats, Metadata *image_metadata)
 		status.aperture = current_aperture;
 		LOG(RPiLux, Debug) << ": estimated lux " << estimated_lux;
 		{
-			std::unique_lock<std::mutex> lock(mutex_);
+			MutexLocker lock(mutex_);
 			status_ = status;
 		}
 		// Overwrite the metadata here as well, so that downstream
diff --git a/src/ipa/raspberrypi/controller/rpi/lux.hpp b/src/ipa/raspberrypi/controller/rpi/lux.hpp
index 3ebd35d1..caa018da 100644
--- a/src/ipa/raspberrypi/controller/rpi/lux.hpp
+++ b/src/ipa/raspberrypi/controller/rpi/lux.hpp
@@ -6,8 +6,7 @@
  */
 #pragma once
 
-#include <mutex>
-
+#include <libcamera/base/mutex.h>
 #include <libcamera/base/utils.h>
 
 #include "../lux_status.h"
@@ -37,7 +36,7 @@ private:
 	double reference_lux_;
 	double current_aperture_;
 	LuxStatus status_;
-	std::mutex mutex_;
+	libcamera::Mutex mutex_;
 };
 
 } // namespace RPiController
-- 
2.34.1.400.ga245620fadb-goog



More information about the libcamera-devel mailing list