[PATCH v2] libcamera: software_isp: Clear IPA context on configure and stop
Milan Zamazal
mzamazal at redhat.com
Mon Oct 14 09:44:31 CEST 2024
Hi Robert,
thank you for the fix.
Robert Mader <robert.mader at collabora.com> writes:
> Like the hardware pipelines do. Not clearing frameContexts otherwise can
> trigger asserts like "Frame context for ... has been overwritten by ..."
> when switching between cameras using the swISP, e.g. on phones.
>
> Clearing the configuration and active state will become more important
> with upcoming changes such as getting the black level from the camera
> helper.
>
> Fixes: 04d171e6 ("libcamera: software_isp: Call Algorithm::queueRequest")
> Signed-off-by: Robert Mader <robert.mader at collabora.com>
Reviewed-by: Milan Zamazal <mzamazal at redhat.com>
> ---
>
> Changes in version 2:
> - Also clear frameContexts as well as other context data on configure
> - Change commit title and message accordingly, previous title:
> "libcamera: software_isp: Clear frameContexts on Stop()"
> ---
> src/ipa/simple/soft_simple.cpp | 6 ++++++
> 1 file changed, 6 insertions(+)
>
> diff --git a/src/ipa/simple/soft_simple.cpp b/src/ipa/simple/soft_simple.cpp
> index b28c7039..3b25d7d0 100644
> --- a/src/ipa/simple/soft_simple.cpp
> +++ b/src/ipa/simple/soft_simple.cpp
> @@ -184,6 +184,11 @@ int IPASoftSimple::configure(const IPAConfigInfo &configInfo)
> const ControlInfo &exposureInfo = sensorInfoMap_.find(V4L2_CID_EXPOSURE)->second;
> const ControlInfo &gainInfo = sensorInfoMap_.find(V4L2_CID_ANALOGUE_GAIN)->second;
>
> + /* Clear the IPA context before the streaming session. */
> + context_.configuration = {};
> + context_.activeState = {};
> + context_.frameContexts.clear();
> +
> context_.configuration.agc.exposureMin = exposureInfo.min().get<int32_t>();
> context_.configuration.agc.exposureMax = exposureInfo.max().get<int32_t>();
> if (!context_.configuration.agc.exposureMin) {
> @@ -245,6 +250,7 @@ int IPASoftSimple::start()
>
> void IPASoftSimple::stop()
> {
> + context_.frameContexts.clear();
> }
>
> void IPASoftSimple::queueRequest(const uint32_t frame, const ControlList &controls)
More information about the libcamera-devel
mailing list