[v4,17/20] libcamera: software_isp: lut: Make CCM available in debayer params
diff mbox series

Message ID 20251210003139.43606-18-bryan.odonoghue@linaro.org
State Superseded
Headers show
Series
  • GPUISP precursor series
Related show

Commit Message

Bryan O'Donoghue Dec. 10, 2025, 12:31 a.m. UTC
Provide the CCM calculated in LUT to the debayer params structure for
consumption in the debayer shaders.

Reviewed-by: Kieran Bingham <kieran.bingham@ideasonboard.com>
Signed-off-by: Bryan O'Donoghue <bryan.odonoghue@linaro.org>
---
 include/libcamera/internal/software_isp/debayer_params.h | 7 +++++++
 src/ipa/simple/algorithms/lut.cpp                        | 1 +
 src/libcamera/software_isp/debayer.cpp                   | 5 +++++
 3 files changed, 13 insertions(+)

Comments

Milan Zamazal Dec. 10, 2025, 8:50 a.m. UTC | #1
Bryan O'Donoghue <bryan.odonoghue@linaro.org> writes:

> Provide the CCM calculated in LUT to the debayer params structure for
> consumption in the debayer shaders.
>
> Reviewed-by: Kieran Bingham <kieran.bingham@ideasonboard.com>
> Signed-off-by: Bryan O'Donoghue <bryan.odonoghue@linaro.org>

Reviewed-by: Milan Zamazal <mzamazal@redhat.com>

> ---
>  include/libcamera/internal/software_isp/debayer_params.h | 7 +++++++
>  src/ipa/simple/algorithms/lut.cpp                        | 1 +
>  src/libcamera/software_isp/debayer.cpp                   | 5 +++++
>  3 files changed, 13 insertions(+)
>
> diff --git a/include/libcamera/internal/software_isp/debayer_params.h b/include/libcamera/internal/software_isp/debayer_params.h
> index 217cd5d92..4b203e211 100644
> --- a/include/libcamera/internal/software_isp/debayer_params.h
> +++ b/include/libcamera/internal/software_isp/debayer_params.h
> @@ -13,6 +13,8 @@
>  #include <array>
>  #include <stdint.h>
>  
> +#include "libcamera/internal/matrix.h"
> +
>  namespace libcamera {
>  
>  struct DebayerParams {
> @@ -49,6 +51,11 @@ struct DebayerParams {
>  	CcmLookupTable greenCcm;
>  	CcmLookupTable blueCcm;
>  	LookupTable gammaLut;
> +
> +	/*
> +	 * Per frame corrections as calculated by the IPA
> +	 */
> +	Matrix<float, 3, 3> ccm;
>  };
>  
>  } /* namespace libcamera */
> diff --git a/src/ipa/simple/algorithms/lut.cpp b/src/ipa/simple/algorithms/lut.cpp
> index d4a79e101..49482d711 100644
> --- a/src/ipa/simple/algorithms/lut.cpp
> +++ b/src/ipa/simple/algorithms/lut.cpp
> @@ -133,6 +133,7 @@ void Lut::prepare(IPAContext &context,
>  		auto &red = params->redCcm;
>  		auto &green = params->greenCcm;
>  		auto &blue = params->blueCcm;
> +		params->ccm = ccm;
>  		for (unsigned int i = 0; i < DebayerParams::kRGBLookupSize; i++) {
>  			red[i].r = ccmValue(i, ccm[0][0]);
>  			red[i].g = ccmValue(i, ccm[1][0]);
> diff --git a/src/libcamera/software_isp/debayer.cpp b/src/libcamera/software_isp/debayer.cpp
> index 32a2c8378..0ee23f36c 100644
> --- a/src/libcamera/software_isp/debayer.cpp
> +++ b/src/libcamera/software_isp/debayer.cpp
> @@ -100,6 +100,11 @@ namespace libcamera {
>   * \brief Gamma lookup table used with color correction matrix
>   */
>  
> +/**
> + * \var DebayerParams::ccm
> + * \brief Per frame colour correction matrix for GPUISP
> + */
> +
>  /**
>   * \class Debayer
>   * \brief Base debayering class

Patch
diff mbox series

diff --git a/include/libcamera/internal/software_isp/debayer_params.h b/include/libcamera/internal/software_isp/debayer_params.h
index 217cd5d92..4b203e211 100644
--- a/include/libcamera/internal/software_isp/debayer_params.h
+++ b/include/libcamera/internal/software_isp/debayer_params.h
@@ -13,6 +13,8 @@ 
 #include <array>
 #include <stdint.h>
 
+#include "libcamera/internal/matrix.h"
+
 namespace libcamera {
 
 struct DebayerParams {
@@ -49,6 +51,11 @@  struct DebayerParams {
 	CcmLookupTable greenCcm;
 	CcmLookupTable blueCcm;
 	LookupTable gammaLut;
+
+	/*
+	 * Per frame corrections as calculated by the IPA
+	 */
+	Matrix<float, 3, 3> ccm;
 };
 
 } /* namespace libcamera */
diff --git a/src/ipa/simple/algorithms/lut.cpp b/src/ipa/simple/algorithms/lut.cpp
index d4a79e101..49482d711 100644
--- a/src/ipa/simple/algorithms/lut.cpp
+++ b/src/ipa/simple/algorithms/lut.cpp
@@ -133,6 +133,7 @@  void Lut::prepare(IPAContext &context,
 		auto &red = params->redCcm;
 		auto &green = params->greenCcm;
 		auto &blue = params->blueCcm;
+		params->ccm = ccm;
 		for (unsigned int i = 0; i < DebayerParams::kRGBLookupSize; i++) {
 			red[i].r = ccmValue(i, ccm[0][0]);
 			red[i].g = ccmValue(i, ccm[1][0]);
diff --git a/src/libcamera/software_isp/debayer.cpp b/src/libcamera/software_isp/debayer.cpp
index 32a2c8378..0ee23f36c 100644
--- a/src/libcamera/software_isp/debayer.cpp
+++ b/src/libcamera/software_isp/debayer.cpp
@@ -100,6 +100,11 @@  namespace libcamera {
  * \brief Gamma lookup table used with color correction matrix
  */
 
+/**
+ * \var DebayerParams::ccm
+ * \brief Per frame colour correction matrix for GPUISP
+ */
+
 /**
  * \class Debayer
  * \brief Base debayering class