@@ -98,6 +98,7 @@ private:
Thread ispWorkerThread_;
SharedMemObject<DebayerParams> sharedParams_;
DebayerParams debayerParams_;
+ bool allocateParamsBuffers();
DmaBufAllocator dmaHeap_;
bool ccmEnabled_;
@@ -88,12 +88,8 @@ SoftwareIsp::SoftwareIsp(PipelineHandler *pipe, const CameraSensor *sensor,
LOG(SoftwareIsp, Error) << "Failed to create DmaBufAllocator object";
return;
}
-
- sharedParams_ = SharedMemObject<DebayerParams>("softIsp_params");
- if (!sharedParams_) {
- LOG(SoftwareIsp, Error) << "Failed to create shared memory for parameters";
+ if (!allocateParamsBuffers())
return;
- }
const GlobalConfiguration &configuration = pipe->cameraManager()->_d()->configuration();
@@ -176,6 +172,17 @@ SoftwareIsp::~SoftwareIsp()
debayer_.reset();
}
+bool SoftwareIsp::allocateParamsBuffers()
+{
+ sharedParams_ = SharedMemObject<DebayerParams>("softIsp_params");
+ if (!sharedParams_) {
+ LOG(SoftwareIsp, Error) << "Failed to create shared memory for parameters";
+ return false;
+ }
+
+ return true;
+}
+
/**
* \fn int SoftwareIsp::loadConfiguration([[maybe_unused]] const std::string &filename)
* \brief Load a configuration from a file
There will be some additions to that code in followup patches and let's not blow the code in SoftwareIsp constructor even more. Signed-off-by: Milan Zamazal <mzamazal@redhat.com> --- .../internal/software_isp/software_isp.h | 1 + src/libcamera/software_isp/software_isp.cpp | 17 ++++++++++++----- 2 files changed, 13 insertions(+), 5 deletions(-)