summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorLaurent Pinchart <laurent.pinchart@ideasonboard.com>2019-02-28 12:29:13 +0200
committerLaurent Pinchart <laurent.pinchart@ideasonboard.com>2019-03-01 15:45:07 +0200
commit61a62ddbd8cda88f20ea26f110aa7041b47b0de7 (patch)
tree040de563aa04fe8cb0bde4e484b08647e591b674 /src
parent40439a933fa7fe0c968a5ea502aeff23e079934d (diff)
libcamera: pipeline_handler: Store pipe and camera in CameraData
Extend the CameraData class with two member variables pipe_ and camera_ that store pointers to the pipeline handler and camera that the CameraData instance is related to. This will be used by pipeline handlers to access the camera and the pipeline in member methods of their CameraData derived classes. Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> Reviewed-by: Niklas Söderlund <niklas.soderlund@ragnatech.se>
Diffstat (limited to 'src')
-rw-r--r--src/libcamera/include/pipeline_handler.h9
-rw-r--r--src/libcamera/pipeline/ipu3/ipu3.cpp9
-rw-r--r--src/libcamera/pipeline/uvcvideo.cpp6
-rw-r--r--src/libcamera/pipeline/vimc.cpp5
-rw-r--r--src/libcamera/pipeline_handler.cpp49
5 files changed, 63 insertions, 15 deletions
diff --git a/src/libcamera/include/pipeline_handler.h b/src/libcamera/include/pipeline_handler.h
index 70cfbe6e..a86ba696 100644
--- a/src/libcamera/include/pipeline_handler.h
+++ b/src/libcamera/include/pipeline_handler.h
@@ -19,6 +19,7 @@ class Camera;
class CameraManager;
class DeviceEnumerator;
class MediaDevice;
+class PipelineHandler;
class Request;
class Stream;
class StreamConfiguration;
@@ -26,10 +27,14 @@ class StreamConfiguration;
class CameraData
{
public:
+ explicit CameraData(PipelineHandler *pipe)
+ : pipe_(pipe)
+ {
+ }
virtual ~CameraData() {}
-protected:
- CameraData() {}
+ Camera *camera_;
+ PipelineHandler *pipe_;
private:
CameraData(const CameraData &) = delete;
diff --git a/src/libcamera/pipeline/ipu3/ipu3.cpp b/src/libcamera/pipeline/ipu3/ipu3.cpp
index 7ab94cca..70c8db1b 100644
--- a/src/libcamera/pipeline/ipu3/ipu3.cpp
+++ b/src/libcamera/pipeline/ipu3/ipu3.cpp
@@ -50,8 +50,11 @@ private:
class IPU3CameraData : public CameraData
{
public:
- IPU3CameraData()
- : cio2_(nullptr), csi2_(nullptr), sensor_(nullptr) {}
+ IPU3CameraData(PipelineHandler *pipe)
+ : CameraData(pipe), cio2_(nullptr), csi2_(nullptr),
+ sensor_(nullptr)
+ {
+ }
~IPU3CameraData()
{
@@ -365,7 +368,7 @@ void PipelineHandlerIPU3::registerCameras()
if (link->setEnabled(true))
continue;
- std::unique_ptr<IPU3CameraData> data = utils::make_unique<IPU3CameraData>();
+ std::unique_ptr<IPU3CameraData> data = utils::make_unique<IPU3CameraData>(this);
std::string cameraName = sensor->name() + " " + std::to_string(id);
std::set<Stream *> streams{ &data->stream_ };
diff --git a/src/libcamera/pipeline/uvcvideo.cpp b/src/libcamera/pipeline/uvcvideo.cpp
index 2858b811..167e0533 100644
--- a/src/libcamera/pipeline/uvcvideo.cpp
+++ b/src/libcamera/pipeline/uvcvideo.cpp
@@ -46,8 +46,8 @@ private:
class UVCCameraData : public CameraData
{
public:
- UVCCameraData()
- : video_(nullptr)
+ UVCCameraData(PipelineHandler *pipe)
+ : CameraData(pipe), video_(nullptr)
{
}
@@ -181,7 +181,7 @@ bool PipelineHandlerUVC::match(DeviceEnumerator *enumerator)
media_->acquire();
- std::unique_ptr<UVCCameraData> data = utils::make_unique<UVCCameraData>();
+ std::unique_ptr<UVCCameraData> data = utils::make_unique<UVCCameraData>(this);
/* Locate and open the default video node. */
for (MediaEntity *entity : media_->entities()) {
diff --git a/src/libcamera/pipeline/vimc.cpp b/src/libcamera/pipeline/vimc.cpp
index 97ec61ba..ad01ce49 100644
--- a/src/libcamera/pipeline/vimc.cpp
+++ b/src/libcamera/pipeline/vimc.cpp
@@ -46,7 +46,8 @@ private:
class VimcCameraData : public CameraData
{
public:
- VimcCameraData()
+ VimcCameraData(PipelineHandler *pipe)
+ : CameraData(pipe)
{
}
@@ -190,7 +191,7 @@ bool PipelineHandlerVimc::match(DeviceEnumerator *enumerator)
media_->acquire();
- std::unique_ptr<VimcCameraData> data = utils::make_unique<VimcCameraData>();
+ std::unique_ptr<VimcCameraData> data = utils::make_unique<VimcCameraData>(this);
/* Locate and open the capture video node. */
data->video_ = new V4L2Device(media_->getEntityByName("Raw Capture 1"));
diff --git a/src/libcamera/pipeline_handler.cpp b/src/libcamera/pipeline_handler.cpp
index c440aa83..ac1acea5 100644
--- a/src/libcamera/pipeline_handler.cpp
+++ b/src/libcamera/pipeline_handler.cpp
@@ -11,6 +11,7 @@
#include "log.h"
#include "media_device.h"
#include "pipeline_handler.h"
+#include "utils.h"
/**
* \file pipeline_handler.h
@@ -45,6 +46,35 @@ LOG_DEFINE_CATEGORY(Pipeline)
*/
/**
+ * \fn CameraData::CameraData(PipelineHandler *pipe)
+ * \brief Construct a CameraData instance for the given pipeline handler
+ * \param[in] pipe The pipeline handler
+ *
+ * The reference to the pipeline handler is stored internally, the caller shall
+ * guarantee that the pointer remains valid as long as the CameraData instance
+ * exists.
+ */
+
+/**
+ * \var CameraData::camera_
+ * \brief The camera related to this CameraData instance
+ *
+ * The camera_ pointer provides access to the Camera object that this instance
+ * is related to. It is set when the Camera is registered with
+ * PipelineHandler::registerCamera() and remains valid until the CameraData
+ * instance is destroyed.
+ */
+
+/**
+ * \var CameraData::pipe_
+ * \brief The pipeline handler related to this CameraData instance
+ *
+ * The pipe_ pointer provides access to the PipelineHandler object that this
+ * instance is related to. It is set when the CameraData instance is created
+ * and remains valid until the instance is destroyed.
+ */
+
+/**
* \class PipelineHandler
* \brief Create and manage cameras based on a set of media devices
*
@@ -218,11 +248,19 @@ PipelineHandler::~PipelineHandler()
* \brief Register a camera to the camera manager and pipeline handler
* \param[in] camera The camera to be added
*
- * This function is called by pipeline handlers to register the cameras they
- * handle with the camera manager.
+ * This method is called by pipeline handlers to register the cameras they
+ * handle with the camera manager. If no CameraData has been associated with
+ * the camera with setCameraData() by the pipeline handler, the method creates
+ * a default CameraData instance for the \a camera.
*/
void PipelineHandler::registerCamera(std::shared_ptr<Camera> camera)
{
+ if (!cameraData_.count(camera.get())) {
+ std::unique_ptr<CameraData> data = utils::make_unique<CameraData>(this);
+ setCameraData(camera.get(), std::move(data));
+ }
+
+ cameraData(camera.get())->camera_ = camera.get();
cameras_.push_back(camera);
manager_->addCamera(std::move(camera));
}
@@ -313,9 +351,10 @@ CameraData *PipelineHandler::cameraData(const Camera *camera)
* information with \a camera. Ownership of \a data is transferred to
* the PipelineHandler.
*
- * Pipeline-specific data can only be set once. Any attempt to call
- * this method after the first one with the same camera won't change
- * the pipeline-specific data.
+ * Pipeline-specific data can only be set once, and shall be set before
+ * registering the camera with registerCamera(). Any attempt to call this
+ * method more than once for the same camera, or to call it after registering
+ * the camera, will not change the pipeline-specific data.
*
* The data can be retrieved by pipeline handlers using the cameraData() method.
*/