[6/6] ipa: rpi: Provide the camera helper with the hardware configuration
diff mbox series

Message ID 20241213094602.2083174-7-naush@raspberrypi.com
State Superseded
Headers show
Series
  • Raspberry Pi: Various changes
Related show

Commit Message

Naushir Patuck Dec. 13, 2024, 9:38 a.m. UTC
Add a CamHelper::setHwConfig() helper used by the IPA to set the
hardware configuartion in use by the pipeline. This will be needed by
the IMX500 camera helper in a future commit to determine if the
metadata buffer is strided.

Signed-off-by: Naushir Patuck <naush@raspberrypi.com>
---
 src/ipa/rpi/cam_helper/cam_helper.cpp | 5 +++++
 src/ipa/rpi/cam_helper/cam_helper.h   | 2 ++
 src/ipa/rpi/common/ipa_base.cpp       | 1 +
 3 files changed, 8 insertions(+)

Comments

David Plowman Dec. 13, 2024, 10:35 a.m. UTC | #1
Hi Naush

Thanks for the patch.

On Fri, 13 Dec 2024 at 09:46, Naushir Patuck <naush@raspberrypi.com> wrote:
>
> Add a CamHelper::setHwConfig() helper used by the IPA to set the
> hardware configuartion in use by the pipeline. This will be needed by

s/configuartion/configuration/    (sorry!)

Other than that:

Reviewed-by: David Plowman <david.plowman@raspberrypi.com>

Thanks
David

> the IMX500 camera helper in a future commit to determine if the
> metadata buffer is strided.
>
> Signed-off-by: Naushir Patuck <naush@raspberrypi.com>
> ---
>  src/ipa/rpi/cam_helper/cam_helper.cpp | 5 +++++
>  src/ipa/rpi/cam_helper/cam_helper.h   | 2 ++
>  src/ipa/rpi/common/ipa_base.cpp       | 1 +
>  3 files changed, 8 insertions(+)
>
> diff --git a/src/ipa/rpi/cam_helper/cam_helper.cpp b/src/ipa/rpi/cam_helper/cam_helper.cpp
> index 6493e88232a4..1422a02e9953 100644
> --- a/src/ipa/rpi/cam_helper/cam_helper.cpp
> +++ b/src/ipa/rpi/cam_helper/cam_helper.cpp
> @@ -156,6 +156,11 @@ void CamHelper::setCameraMode(const CameraMode &mode)
>         }
>  }
>
> +void CamHelper::setHwConfig(const Controller::HardwareConfig &hwConfig)
> +{
> +       hwConfig_ = hwConfig;
> +}
> +
>  void CamHelper::getDelays(int &exposureDelay, int &gainDelay,
>                           int &vblankDelay, int &hblankDelay) const
>  {
> diff --git a/src/ipa/rpi/cam_helper/cam_helper.h b/src/ipa/rpi/cam_helper/cam_helper.h
> index 4a4ab5e68cba..fb7eb3202e79 100644
> --- a/src/ipa/rpi/cam_helper/cam_helper.h
> +++ b/src/ipa/rpi/cam_helper/cam_helper.h
> @@ -76,6 +76,7 @@ public:
>         CamHelper(std::unique_ptr<MdParser> parser, unsigned int frameIntegrationDiff);
>         virtual ~CamHelper();
>         void setCameraMode(const CameraMode &mode);
> +       void setHwConfig(const Controller::HardwareConfig &hwConfig);
>         virtual void prepare(libcamera::Span<const uint8_t> buffer,
>                              Metadata &metadata);
>         virtual void process(StatisticsPtr &stats, Metadata &metadata);
> @@ -108,6 +109,7 @@ protected:
>
>         std::unique_ptr<MdParser> parser_;
>         CameraMode mode_;
> +       Controller::HardwareConfig hwConfig_;
>
>  private:
>         /*
> diff --git a/src/ipa/rpi/common/ipa_base.cpp b/src/ipa/rpi/common/ipa_base.cpp
> index b3656cbc730b..a7d27ef66ec4 100644
> --- a/src/ipa/rpi/common/ipa_base.cpp
> +++ b/src/ipa/rpi/common/ipa_base.cpp
> @@ -161,6 +161,7 @@ int32_t IpaBase::init(const IPASettings &settings, const InitParams &params, Ini
>         lensPresent_ = params.lensPresent;
>
>         controller_.initialise();
> +       helper_->setHwConfig(controller_.getHardwareConfig());
>
>         /* Return the controls handled by the IPA */
>         ControlInfoMap::Map ctrlMap = ipaControls;
> --
> 2.43.0
>

Patch
diff mbox series

diff --git a/src/ipa/rpi/cam_helper/cam_helper.cpp b/src/ipa/rpi/cam_helper/cam_helper.cpp
index 6493e88232a4..1422a02e9953 100644
--- a/src/ipa/rpi/cam_helper/cam_helper.cpp
+++ b/src/ipa/rpi/cam_helper/cam_helper.cpp
@@ -156,6 +156,11 @@  void CamHelper::setCameraMode(const CameraMode &mode)
 	}
 }
 
+void CamHelper::setHwConfig(const Controller::HardwareConfig &hwConfig)
+{
+	hwConfig_ = hwConfig;
+}
+
 void CamHelper::getDelays(int &exposureDelay, int &gainDelay,
 			  int &vblankDelay, int &hblankDelay) const
 {
diff --git a/src/ipa/rpi/cam_helper/cam_helper.h b/src/ipa/rpi/cam_helper/cam_helper.h
index 4a4ab5e68cba..fb7eb3202e79 100644
--- a/src/ipa/rpi/cam_helper/cam_helper.h
+++ b/src/ipa/rpi/cam_helper/cam_helper.h
@@ -76,6 +76,7 @@  public:
 	CamHelper(std::unique_ptr<MdParser> parser, unsigned int frameIntegrationDiff);
 	virtual ~CamHelper();
 	void setCameraMode(const CameraMode &mode);
+	void setHwConfig(const Controller::HardwareConfig &hwConfig);
 	virtual void prepare(libcamera::Span<const uint8_t> buffer,
 			     Metadata &metadata);
 	virtual void process(StatisticsPtr &stats, Metadata &metadata);
@@ -108,6 +109,7 @@  protected:
 
 	std::unique_ptr<MdParser> parser_;
 	CameraMode mode_;
+	Controller::HardwareConfig hwConfig_;
 
 private:
 	/*
diff --git a/src/ipa/rpi/common/ipa_base.cpp b/src/ipa/rpi/common/ipa_base.cpp
index b3656cbc730b..a7d27ef66ec4 100644
--- a/src/ipa/rpi/common/ipa_base.cpp
+++ b/src/ipa/rpi/common/ipa_base.cpp
@@ -161,6 +161,7 @@  int32_t IpaBase::init(const IPASettings &settings, const InitParams &params, Ini
 	lensPresent_ = params.lensPresent;
 
 	controller_.initialise();
+	helper_->setHwConfig(controller_.getHardwareConfig());
 
 	/* Return the controls handled by the IPA */
 	ControlInfoMap::Map ctrlMap = ipaControls;