@@ -16,13 +16,13 @@
#include <libcamera/ipa/ipa_interface.h>
#include <libcamera/ipa/ipa_module_info.h>
-#include "libcamera/internal/camera_manager.h"
#include "libcamera/internal/pub_key.h"
namespace libcamera {
LOG_DECLARE_CATEGORY(IPAManager)
+class CameraManager;
class GlobalConfiguration;
class IPAModule;
class PipelineHandler;
@@ -30,7 +30,7 @@ class PipelineHandler;
class IPAManager
{
public:
- IPAManager(const GlobalConfiguration &configuration);
+ IPAManager(const CameraManager &cm);
~IPAManager();
template<typename T>
@@ -43,9 +43,9 @@ public:
auto proxy = [&]() -> std::unique_ptr<T> {
if (isSignatureValid(m))
- return std::make_unique<typename T::Threaded>(m, configuration_);
+ return std::make_unique<typename T::Threaded>(m, cm_);
else
- return std::make_unique<typename T::Isolated>(m, configuration_);
+ return std::make_unique<typename T::Isolated>(m, cm_);
}();
if (!proxy->isValid()) {
@@ -73,7 +73,7 @@ private:
bool isSignatureValid(IPAModule *ipa) const;
- const GlobalConfiguration &configuration_;
+ const CameraManager &cm_;
std::vector<std::unique_ptr<IPAModule>> modules_;
#if HAVE_IPA_PUBKEY
@@ -13,7 +13,7 @@
#include <libcamera/ipa/ipa_interface.h>
-#include "libcamera/internal/global_configuration.h"
+#include "libcamera/internal/camera_manager.h"
namespace libcamera {
@@ -28,7 +28,7 @@ public:
ProxyRunning,
};
- IPAProxy(IPAModule *ipam, const GlobalConfiguration &configuration);
+ IPAProxy(IPAModule *ipam, const CameraManager &cm);
~IPAProxy();
bool isValid() const { return valid_; }
@@ -12,15 +12,15 @@
#include <stdint.h>
#include <time.h>
-#include <libcamera/base/log.h>
-#include "libcamera/internal/global_configuration.h"
namespace libcamera {
+class CameraManager;
+
class Benchmark
{
public:
- Benchmark(const GlobalConfiguration &configuration);
+ Benchmark(const CameraManager &cm);
~Benchmark();
void startFrame(void);
@@ -19,7 +19,6 @@
#include "libcamera/internal/bayer_format.h"
#include "libcamera/internal/framebuffer.h"
-#include "libcamera/internal/global_configuration.h"
#include "libcamera/internal/shared_mem_object.h"
#include "libcamera/internal/software_isp/swisp_stats.h"
@@ -27,14 +26,15 @@
namespace libcamera {
-class PixelFormat;
+class CameraManager;
class MappedFrameBuffer;
+class PixelFormat;
struct StreamConfiguration;
class SwStatsCpu
{
public:
- SwStatsCpu(const GlobalConfiguration &configuration);
+ SwStatsCpu(const CameraManager &cm);
~SwStatsCpu() = default;
/*
@@ -93,7 +93,8 @@ void CameraManager::Private::run()
int CameraManager::Private::init()
{
- ipaManager_ = std::make_unique<IPAManager>(configuration());
+ CameraManager *const o = LIBCAMERA_O_PTR();
+ ipaManager_ = std::make_unique<IPAManager>(*o);
enumerator_ = DeviceEnumerator::create();
if (!enumerator_ || enumerator_->enumerate())
@@ -100,13 +100,16 @@ LOG_DEFINE_CATEGORY(IPAManager)
/**
* \brief Construct an IPAManager instance
+ * \param[in] cm The camera manager
*
* The IPAManager class is meant to only be instantiated once, by the
* CameraManager.
*/
-IPAManager::IPAManager(const GlobalConfiguration &configuration)
- : configuration_(configuration)
+IPAManager::IPAManager(const CameraManager &cm)
+ : cm_(cm)
{
+ const GlobalConfiguration &configuration = cm._d()->configuration();
+
#if HAVE_IPA_PUBKEY
if (!pubKey_.isValid())
LOG(IPAManager, Warning) << "Public key not valid";
@@ -117,13 +117,19 @@ std::string ipaConfigurationFile(const std::string &ipaName, const std::string &
/**
* \brief Construct an IPAProxy instance
* \param[in] ipam The IPA module
- * \param[in] configuration The global configuration
+ * \param[in] cm The camera manager
*/
-IPAProxy::IPAProxy(IPAModule *ipam, const GlobalConfiguration &configuration)
- : valid_(false), state_(ProxyStopped), ipam_(ipam),
- configPaths_(configuration.envListOption("LIBCAMERA_IPA_CONFIG_PATH", { "ipa", "config_paths" }).value_or(std::vector<std::string>())),
- execPaths_(configuration.envListOption("LIBCAMERA_IPA_PROXY_PATH", { "ipa", "proxy_paths" }).value_or(std::vector<std::string>()))
+IPAProxy::IPAProxy(IPAModule *ipam, const CameraManager &cm)
+ : valid_(false), state_(ProxyStopped), ipam_(ipam)
{
+ const GlobalConfiguration &configuration = cm._d()->configuration();
+
+ configPaths_ = configuration.envListOption("LIBCAMERA_IPA_CONFIG_PATH",
+ { "ipa", "config_paths" })
+ .value_or(std::vector<std::string>());
+ execPaths_ = configuration.envListOption("LIBCAMERA_IPA_PROXY_PATH",
+ { "ipa", "proxy_paths" })
+ .value_or(std::vector<std::string>());
}
IPAProxy::~IPAProxy()
@@ -12,6 +12,9 @@
#include <libcamera/base/log.h>
+#include "libcamera/internal/camera_manager.h"
+#include "libcamera/internal/global_configuration.h"
+
namespace libcamera {
LOG_DEFINE_CATEGORY(Benchmark)
@@ -26,8 +29,10 @@ LOG_DEFINE_CATEGORY(Benchmark)
/**
* \brief Constructs a Benchmark object
*/
-Benchmark::Benchmark(const GlobalConfiguration &configuration)
+Benchmark::Benchmark(const CameraManager &cm)
{
+ const GlobalConfiguration &configuration = cm._d()->configuration();
+
skipBeforeMeasure_ = configuration.option<unsigned int>(
{ "software_isp", "measure", "skip" })
.value_or(skipBeforeMeasure_);
@@ -18,12 +18,6 @@ namespace libcamera {
* \brief Struct to hold the debayer parameters.
*/
-/**
- * \fn Debayer::Debayer(const GlobalConfiguration &configuration)
- * \brief Construct a Debayer object
- * \param[in] configuration Global configuration reference
- */
-
/**
* \var DebayerParams::kRGBLookupSize
* \brief Size of a color lookup table
@@ -129,7 +123,12 @@ namespace libcamera {
LOG_DEFINE_CATEGORY(Debayer)
-Debayer::Debayer(const GlobalConfiguration &configuration) : bench_(configuration)
+/**
+ * \brief Construct a Debayer object
+ * \param[in] cm The camera manager
+ */
+Debayer::Debayer(const CameraManager &cm)
+ : bench_(cm)
{
/* Initialize color lookup tables */
for (unsigned int i = 0; i < DebayerParams::kRGBLookupSize; i++) {
@@ -22,12 +22,12 @@
#include "libcamera/internal/bayer_format.h"
#include "libcamera/internal/dma_buf_allocator.h"
-#include "libcamera/internal/global_configuration.h"
#include "libcamera/internal/software_isp/benchmark.h"
#include "libcamera/internal/software_isp/debayer_params.h"
namespace libcamera {
+class CameraManager;
class FrameBuffer;
LOG_DECLARE_CATEGORY(Debayer)
@@ -35,7 +35,7 @@ LOG_DECLARE_CATEGORY(Debayer)
class Debayer : public Object
{
public:
- Debayer(const GlobalConfiguration &configuration);
+ Debayer(const CameraManager &cm);
virtual ~Debayer() = 0;
virtual int configure(const StreamConfiguration &inputCfg,
@@ -38,10 +38,10 @@ namespace libcamera {
/**
* \brief Constructs a DebayerCpu object
* \param[in] stats Pointer to the stats object to use
- * \param[in] configuration The global configuration
+ * \param[in] cm The camera manager
*/
-DebayerCpu::DebayerCpu(std::unique_ptr<SwStatsCpu> stats, const GlobalConfiguration &configuration)
- : Debayer(configuration), stats_(std::move(stats))
+DebayerCpu::DebayerCpu(std::unique_ptr<SwStatsCpu> stats, const CameraManager &cm)
+ : Debayer(cm), stats_(std::move(stats))
{
/*
* Reading from uncached buffers may be very slow.
@@ -54,6 +54,7 @@ DebayerCpu::DebayerCpu(std::unique_ptr<SwStatsCpu> stats, const GlobalConfigurat
* \todo Make memcpy automatic based on runtime detection of platform
* capabilities.
*/
+ const GlobalConfiguration &configuration = cm._d()->configuration();
enableInputMemcpy_ =
configuration.option<bool>({ "software_isp", "copy_input_buffer" }).value_or(true);
}
@@ -18,6 +18,7 @@
#include <libcamera/base/object.h>
#include "libcamera/internal/bayer_format.h"
+#include "libcamera/internal/camera_manager.h"
#include "libcamera/internal/software_isp/swstats_cpu.h"
#include "debayer.h"
@@ -27,7 +28,7 @@ namespace libcamera {
class DebayerCpu : public Debayer
{
public:
- DebayerCpu(std::unique_ptr<SwStatsCpu> stats, const GlobalConfiguration &configuration);
+ DebayerCpu(std::unique_ptr<SwStatsCpu> stats, const CameraManager &cm);
~DebayerCpu();
int configure(const StreamConfiguration &inputCfg,
@@ -29,13 +29,12 @@ namespace libcamera {
*/
/**
- * \fn DebayerEGL::DebayerEGL(std::unique_ptr<SwStatsCpu> stats, const GlobalConfiguration &configuration)
* \brief Construct a DebayerEGL object
* \param[in] stats Statistics processing object
- * \param[in] configuration Global configuration reference
+ * \param[in] cm The camera manager
*/
-DebayerEGL::DebayerEGL(std::unique_ptr<SwStatsCpu> stats, const GlobalConfiguration &configuration)
- : Debayer(configuration), stats_(std::move(stats))
+DebayerEGL::DebayerEGL(std::unique_ptr<SwStatsCpu> stats, const CameraManager &cm)
+ : Debayer(cm), stats_(std::move(stats))
{
}
@@ -35,10 +35,12 @@ namespace libcamera {
#define DEBAYER_EGL_MIN_SIMPLE_RGB_GAIN_TEXTURE_UNITS 4
#define DEBAYER_OPENGL_COORDS 4
+class CameraManager;
+
class DebayerEGL : public Debayer
{
public:
- DebayerEGL(std::unique_ptr<SwStatsCpu> stats, const GlobalConfiguration &configuration);
+ DebayerEGL(std::unique_ptr<SwStatsCpu> stats, const CameraManager &cm);
~DebayerEGL();
int configure(const StreamConfiguration &inputCfg,
@@ -111,9 +111,9 @@ SoftwareIsp::SoftwareIsp(PipelineHandler *pipe, const CameraSensor *sensor,
return;
}
- const GlobalConfiguration &configuration = pipe->cameraManager()->_d()->configuration();
+ const CameraManager &cm = *pipe->cameraManager();
- auto stats = std::make_unique<SwStatsCpu>(configuration);
+ auto stats = std::make_unique<SwStatsCpu>(cm);
if (!stats->isValid()) {
LOG(SoftwareIsp, Error) << "Failed to create SwStatsCpu object";
return;
@@ -123,6 +123,7 @@ SoftwareIsp::SoftwareIsp(PipelineHandler *pipe, const CameraSensor *sensor,
bool gpuIspEnabled;
#if HAVE_DEBAYER_EGL
+ const GlobalConfiguration &configuration = cm._d()->configuration();
std::optional<std::string> softISPMode = configuration.envOption("LIBCAMERA_SOFTISP_MODE", { "software_isp", "mode" });
if (softISPMode) {
if (softISPMode != "gpu" && softISPMode != "cpu") {
@@ -133,12 +134,12 @@ SoftwareIsp::SoftwareIsp(PipelineHandler *pipe, const CameraSensor *sensor,
}
if (!softISPMode || softISPMode == "gpu") {
- debayer_ = std::make_unique<DebayerEGL>(std::move(stats), configuration);
+ debayer_ = std::make_unique<DebayerEGL>(std::move(stats), cm);
gpuIspEnabled = true;
}
#endif
if (!debayer_) {
- debayer_ = std::make_unique<DebayerCpu>(std::move(stats), configuration);
+ debayer_ = std::make_unique<DebayerCpu>(std::move(stats), cm);
gpuIspEnabled = false;
}
@@ -36,9 +36,9 @@ namespace libcamera {
*/
/**
- * \fn SwStatsCpu::SwStatsCpu(const GlobalConfiguration &configuration)
+ * \fn SwStatsCpu::SwStatsCpu(const CameraManager &cm)
* \brief Construct a SwStatsCpu object
- * \param[in] configuration Global configuration reference
+ * \param[in] cm The camera manager
*
* Creates a SwStatsCpu object and initialises shared memory for statistics
* exchange.
@@ -154,8 +154,8 @@ namespace libcamera {
LOG_DEFINE_CATEGORY(SwStatsCpu)
-SwStatsCpu::SwStatsCpu(const GlobalConfiguration &configuration)
- : sharedStats_("softIsp_stats"), bench_(configuration)
+SwStatsCpu::SwStatsCpu(const CameraManager &cm)
+ : sharedStats_("softIsp_stats"), bench_(cm)
{
if (!sharedStats_)
LOG(SwStatsCpu, Error)
@@ -47,7 +47,6 @@ public:
notifier_.reset();
ipa_.reset();
ipaManager_.reset();
- config_.reset();
cameraManager_.reset();
}
@@ -90,8 +89,7 @@ protected:
notifier_->activated.connect(this, &IPAInterfaceTest::readTrace);
/* Create the IPA manager. */
- config_ = std::make_unique<GlobalConfiguration>();
- ipaManager_ = std::make_unique<IPAManager>(*config_);
+ ipaManager_ = std::make_unique<IPAManager>(*cameraManager_);
return TestPass;
}
@@ -169,7 +167,6 @@ private:
std::shared_ptr<PipelineHandler> pipe_;
std::unique_ptr<ipa::vimc::IPAProxyVimc> ipa_;
std::unique_ptr<CameraManager> cameraManager_;
- std::unique_ptr<GlobalConfiguration> config_;
std::unique_ptr<IPAManager> ipaManager_;
enum ipa::vimc::IPAOperationCode trace_;
std::unique_ptr<EventNotifier> notifier_;
@@ -45,8 +45,8 @@ namespace {{ns}} {
{% endfor %}
{%- endif %}
-{{proxy_name}}Threaded::{{proxy_name}}Threaded(IPAModule *ipam, const GlobalConfiguration &configuration)
- : {{proxy_name}}(ipam, configuration), thread_("{{proxy_name}}")
+{{proxy_name}}Threaded::{{proxy_name}}Threaded(IPAModule *ipam, const CameraManager &cm)
+ : {{proxy_name}}(ipam, cm), thread_("{{proxy_name}}")
{
LOG(IPAProxy, Debug)
<< "initializing {{module_name}} proxy in thread: loading IPA from "
@@ -127,8 +127,8 @@ namespace {{ns}} {
/* ========================================================================== */
-{{proxy_name}}Isolated::{{proxy_name}}Isolated(IPAModule *ipam, const GlobalConfiguration &configuration)
- : {{proxy_name}}(ipam, configuration),
+{{proxy_name}}Isolated::{{proxy_name}}Isolated(IPAModule *ipam, const CameraManager &cm)
+ : {{proxy_name}}(ipam, cm),
controlSerializer_(ControlSerializer::Role::Proxy), seq_(0)
{
LOG(IPAProxy, Debug)
@@ -50,7 +50,7 @@ protected:
class {{proxy_name}}Threaded : public {{proxy_name}}
{
public:
- {{proxy_name}}Threaded(IPAModule *ipam, const GlobalConfiguration &configuration);
+ {{proxy_name}}Threaded(IPAModule *ipam, const CameraManager &cm);
~{{proxy_name}}Threaded();
{% for method in interface_main.methods %}
@@ -112,7 +112,7 @@ private:
class {{proxy_name}}Isolated : public {{proxy_name}}
{
public:
- {{proxy_name}}Isolated(IPAModule *ipam, const GlobalConfiguration &configuration);
+ {{proxy_name}}Isolated(IPAModule *ipam, const CameraManager &cm);
~{{proxy_name}}Isolated();
{% for method in interface_main.methods %}
The GlobalConfiguration is explicitly passed around through constructors of various objects that need access to the configuration. This ad-hoc solution works for the specific use cases it was meant to support, but isn't very generic. We have a top-level object in libcamera, the CameraManager, that also needs to be accessed from various locations and is passed to object constructors. Standardize on passing the CameraManager everywhere, and access the global configuration through it. Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> --- include/libcamera/internal/ipa_manager.h | 10 +++++----- include/libcamera/internal/ipa_proxy.h | 4 ++-- .../libcamera/internal/software_isp/benchmark.h | 6 +++--- .../internal/software_isp/swstats_cpu.h | 6 +++--- src/libcamera/camera_manager.cpp | 3 ++- src/libcamera/ipa_manager.cpp | 7 +++++-- src/libcamera/ipa_proxy.cpp | 16 +++++++++++----- src/libcamera/software_isp/benchmark.cpp | 7 ++++++- src/libcamera/software_isp/debayer.cpp | 13 ++++++------- src/libcamera/software_isp/debayer.h | 4 ++-- src/libcamera/software_isp/debayer_cpu.cpp | 7 ++++--- src/libcamera/software_isp/debayer_cpu.h | 3 ++- src/libcamera/software_isp/debayer_egl.cpp | 7 +++---- src/libcamera/software_isp/debayer_egl.h | 4 +++- src/libcamera/software_isp/software_isp.cpp | 9 +++++---- src/libcamera/software_isp/swstats_cpu.cpp | 8 ++++---- test/ipa/ipa_interface_test.cpp | 5 +---- .../module_ipa_proxy.cpp.tmpl | 8 ++++---- .../libcamera_templates/module_ipa_proxy.h.tmpl | 4 ++-- 19 files changed, 73 insertions(+), 58 deletions(-)