[libcamera-devel] [PATCH v3 17/17] ipa: rkisp1: Store configuration data in context

Jacopo Mondi jacopo at jmondi.org
Thu Aug 18 11:44:10 CEST 2022


The RkISP1 IPA module stores per-configuration session data, such as the
sensor and lens controls and the sensor information, in class member
variables.

As the IPAContext structure has exactly a place for session-specific
configuration data, move those information in the context_ and remove
them from the class.

Signed-off-by: Jacopo Mondi <jacopo at jmondi.org>
---
 src/ipa/rkisp1/ipa_context.cpp | 15 +++++++++++++++
 src/ipa/rkisp1/ipa_context.h   |  6 ++++++
 src/ipa/rkisp1/rkisp1.cpp      | 33 ++++++++++++++-------------------
 3 files changed, 35 insertions(+), 19 deletions(-)

diff --git a/src/ipa/rkisp1/ipa_context.cpp b/src/ipa/rkisp1/ipa_context.cpp
index ef8bb8e931c8..e31059e52cee 100644
--- a/src/ipa/rkisp1/ipa_context.cpp
+++ b/src/ipa/rkisp1/ipa_context.cpp
@@ -100,6 +100,21 @@ namespace libcamera::ipa::rkisp1 {
  * \brief Sensor output resolution
  */
 
+/**
+ * \var IPASessionConfiguration::sensorCtrls
+ * \brief The list of V4L2 sensor controls limits
+ */
+
+/**
+ * \var IPASessionConfiguration::lensCtrls
+ * \brief The list of V4L2 lens controls limits
+ */
+
+/**
+ * \var IPASessionConfiguration::sensorInfo
+ * \brief The sensor configuration for the streaming session
+ */
+
 /**
  * \var IPAFrameContext::agc
  * \brief Context for the Automatic Gain Control algorithm
diff --git a/src/ipa/rkisp1/ipa_context.h b/src/ipa/rkisp1/ipa_context.h
index dd756f4025d1..6151f35af900 100644
--- a/src/ipa/rkisp1/ipa_context.h
+++ b/src/ipa/rkisp1/ipa_context.h
@@ -14,6 +14,8 @@
 
 #include <libcamera/geometry.h>
 
+#include <libcamera/ipa/core_ipa_interface.h>
+
 #include <libipa/fc_queue.h>
 
 namespace libcamera {
@@ -41,6 +43,10 @@ struct IPASessionConfiguration {
 	struct {
 		rkisp1_cif_isp_version revision;
 	} hw;
+
+	ControlInfoMap sensorCtrls;
+	ControlInfoMap lensCtrls;
+	IPACameraSensorInfo sensorInfo;
 };
 
 struct IPAActiveState {
diff --git a/src/ipa/rkisp1/rkisp1.cpp b/src/ipa/rkisp1/rkisp1.cpp
index a1834034e617..01d64c48b126 100644
--- a/src/ipa/rkisp1/rkisp1.cpp
+++ b/src/ipa/rkisp1/rkisp1.cpp
@@ -71,9 +71,6 @@ private:
 	std::map<unsigned int, FrameBuffer> buffers_;
 	std::map<unsigned int, MappedFrameBuffer> mappedBuffers_;
 
-	ControlInfoMap sensorCtrls_;
-	std::optional<ControlInfoMap> lensCtrls_;
-
 	/* revision-specific data */
 	rkisp1_cif_isp_version hwRevision_;
 	unsigned int hwHistBinNMax_;
@@ -211,9 +208,17 @@ bool IPARkISP1::validateSensorControls(const ControlInfoMap &sensorControls)
 
 void IPARkISP1::updateSessionConfiguration(const IPAConfigInfo &configInfo)
 {
-	const IPACameraSensorInfo &sensorInfo = configInfo.sensorInfo;
-	const ControlInfoMap &sensorControls = configInfo.sensorControls;
+	/* Clear the IPA context before the streaming session. */
+	context_.frameContexts.clear();
+	context_ = {};
+
+	context_.configuration.sensorCtrls = configInfo.sensorControls;
+	context_.configuration.lensCtrls = configInfo.lensControls;
+
+	/* Set the hardware revision for the algorithms. */
+	context_.configuration.hw.revision = hwRevision_;
 
+	const ControlInfoMap &sensorControls = configInfo.sensorControls;
 	const ControlInfo &v4l2Exposure = sensorControls.find(V4L2_CID_EXPOSURE)->second;
 	const ControlInfo &v4l2Gain = sensorControls.find(V4L2_CID_ANALOGUE_GAIN)->second;
 	int32_t minExposure = v4l2Exposure.min().get<int32_t>();
@@ -226,16 +231,9 @@ void IPARkISP1::updateSessionConfiguration(const IPAConfigInfo &configInfo)
 		<< "Exposure: " << minExposure << "-" << maxExposure
 		<< " Gain: " << minGain << "-" << maxGain;
 
-	/* Clear the IPA context before the streaming session. */
-	context_.frameContexts.clear();
-	context_ = {};
-
-	/* Set the hardware revision for the algorithms. */
-	context_.configuration.hw.revision = hwRevision_;
-
-	context_.configuration.sensor.size = sensorInfo.outputSize;
-	context_.configuration.sensor.lineDuration = sensorInfo.lineLength * 1.0s
-						   / sensorInfo.pixelRate;
+	context_.configuration.sensor.size = configInfo.sensorInfo.outputSize;
+	context_.configuration.sensor.lineDuration = configInfo.sensorInfo.lineLength * 1.0s
+						   / configInfo.sensorInfo.pixelRate;
 
 	/*
 	 * When the AGC computes the new exposure values for a frame, it needs
@@ -259,9 +257,6 @@ int IPARkISP1::configure(const IPAConfigInfo &configInfo)
 		return -EINVAL;
 	}
 
-	sensorCtrls_ = configInfo.sensorControls;
-	lensCtrls_ = configInfo.lensControls;
-
 	updateSessionConfiguration(configInfo);
 
 	for (auto const &algo : algorithms()) {
@@ -358,7 +353,7 @@ void IPARkISP1::setControls(unsigned int frame)
 	uint32_t exposure = context_.activeState.agc.exposure;
 	uint32_t gain = camHelper_->gainCode(context_.activeState.agc.gain);
 
-	ControlList ctrls(sensorCtrls_);
+	ControlList ctrls(context_.configuration.sensorCtrls);
 	ctrls.set(V4L2_CID_EXPOSURE, static_cast<int32_t>(exposure));
 	ctrls.set(V4L2_CID_ANALOGUE_GAIN, static_cast<int32_t>(gain));
 
-- 
2.37.2



More information about the libcamera-devel mailing list