libcamera  v0.0.1
Supporting cameras in Linux since 2019
pipeline_handler.h
Go to the documentation of this file.
1 /* SPDX-License-Identifier: LGPL-2.1-or-later */
2 /*
3  * Copyright (C) 2018, Google Inc.
4  *
5  * pipeline_handler.h - Pipeline handler infrastructure
6  */
7 
8 #pragma once
9 
10 #include <memory>
11 #include <queue>
12 #include <set>
13 #include <string>
14 #include <sys/types.h>
15 #include <vector>
16 
17 #include <libcamera/base/mutex.h>
18 #include <libcamera/base/object.h>
19 
20 #include <libcamera/controls.h>
21 #include <libcamera/stream.h>
22 
24 
25 namespace libcamera {
26 
27 class Camera;
28 class CameraConfiguration;
29 class CameraManager;
30 class DeviceEnumerator;
31 class DeviceMatch;
32 class FrameBuffer;
33 class MediaDevice;
34 class PipelineHandler;
35 class Request;
36 
37 class PipelineHandler : public std::enable_shared_from_this<PipelineHandler>,
38  public Object
39 {
40 public:
42  virtual ~PipelineHandler();
43 
44  virtual bool match(DeviceEnumerator *enumerator) = 0;
46  const DeviceMatch &dm);
47 
48  bool acquire();
49  void release();
50 
52  const StreamRoles &roles) = 0;
53  virtual int configure(Camera *camera, CameraConfiguration *config) = 0;
54 
55  virtual int exportFrameBuffers(Camera *camera, Stream *stream,
56  std::vector<std::unique_ptr<FrameBuffer>> *buffers) = 0;
57 
58  virtual int start(Camera *camera, const ControlList *controls) = 0;
59  void stop(Camera *camera);
60  bool hasPendingRequests(const Camera *camera) const;
61 
62  void registerRequest(Request *request);
63  void queueRequest(Request *request);
64 
65  bool completeBuffer(Request *request, FrameBuffer *buffer);
66  void completeRequest(Request *request);
67 
68  const char *name() const { return name_; }
69 
70 protected:
71  void registerCamera(std::shared_ptr<Camera> camera);
72  void hotplugMediaDevice(MediaDevice *media);
73 
74  virtual int queueRequestDevice(Camera *camera, Request *request) = 0;
75  virtual void stopDevice(Camera *camera) = 0;
76 
78 
79 private:
80  void unlockMediaDevices();
81 
82  void mediaDeviceDisconnected(MediaDevice *media);
83  virtual void disconnect();
84 
85  void doQueueRequest(Request *request);
86  void doQueueRequests();
87 
88  std::vector<std::shared_ptr<MediaDevice>> mediaDevices_;
89  std::vector<std::weak_ptr<Camera>> cameras_;
90 
91  std::queue<Request *> waitingRequests_;
92 
93  const char *name_;
94 
95  Mutex lock_;
96  unsigned int useCount_ LIBCAMERA_TSA_GUARDED_BY(lock_);
97 
98  friend class PipelineHandlerFactoryBase;
99 };
100 
102 {
103 public:
104  PipelineHandlerFactoryBase(const char *name);
105  virtual ~PipelineHandlerFactoryBase() = default;
106 
107  std::shared_ptr<PipelineHandler> create(CameraManager *manager) const;
108 
109  const std::string &name() const { return name_; }
110 
111  static std::vector<PipelineHandlerFactoryBase *> &factories();
112 
113 private:
114  static void registerType(PipelineHandlerFactoryBase *factory);
115 
116  virtual std::unique_ptr<PipelineHandler>
117  createInstance(CameraManager *manager) const = 0;
118 
119  std::string name_;
120 };
121 
122 template<typename _PipelineHandler>
124 {
125 public:
128  {
129  }
130 
131  std::unique_ptr<PipelineHandler>
132  createInstance(CameraManager *manager) const override
133  {
134  return std::make_unique<_PipelineHandler>(manager);
135  }
136 };
137 
138 #define REGISTER_PIPELINE_HANDLER(handler) \
139 static PipelineHandlerFactory<handler> global_##handler##Factory(#handler);
140 
141 } /* namespace libcamera */
Hold configuration for streams of the camera.
Definition: camera.h:33
Provide access and manage all cameras in the system.
Definition: camera_manager.h:24
Camera device.
Definition: camera.h:87
Associate a list of ControlId with their values for an object.
Definition: controls.h:350
Enumerate, store and search media devices.
Definition: device_enumerator.h:35
Description of a media device search pattern.
Definition: device_enumerator.h:21
Frame buffer data and its associated dynamic metadata.
Definition: framebuffer.h:50
The MediaDevice represents a Media Controller device with its full graph of connected objects.
Definition: media_device.h:26
std::mutex wrapper with clang thread safety annotation
Definition: mutex.h:122
Base object to support automatic signal disconnection.
Definition: object.h:25
Base class for pipeline handler factories.
Definition: pipeline_handler.h:102
const std::string & name() const
Retrieve the factory name.
Definition: pipeline_handler.h:109
PipelineHandlerFactoryBase(const char *name)
Construct a pipeline handler factory base.
Definition: pipeline_handler.cpp:663
static std::vector< PipelineHandlerFactoryBase * > & factories()
Retrieve the list of all pipeline handler factories.
Definition: pipeline_handler.cpp:708
std::shared_ptr< PipelineHandler > create(CameraManager *manager) const
Create an instance of the PipelineHandler corresponding to the factory.
Definition: pipeline_handler.cpp:676
Registration of PipelineHandler classes and creation of instances.
Definition: pipeline_handler.h:124
PipelineHandlerFactory(const char *name)
Construct a pipeline handler factory.
Definition: pipeline_handler.h:126
std::unique_ptr< PipelineHandler > createInstance(CameraManager *manager) const override
Create an instance of the PipelineHandler corresponding to the factory.
Definition: pipeline_handler.h:132
Create and manage cameras based on a set of media devices.
Definition: pipeline_handler.h:39
virtual int queueRequestDevice(Camera *camera, Request *request)=0
Queue a request to the device.
bool acquire()
Acquire exclusive access to the pipeline handler for the process.
Definition: pipeline_handler.cpp:164
void hotplugMediaDevice(MediaDevice *media)
Enable hotplug handling for a media device.
Definition: pipeline_handler.cpp:572
virtual void stopDevice(Camera *camera)=0
Stop capturing from all running streams.
PipelineHandler(CameraManager *manager)
Construct a PipelineHandler instance.
Definition: pipeline_handler.cpp:69
void completeRequest(Request *request)
Signal request completion.
Definition: pipeline_handler.cpp:505
const char * name() const
Retrieve the pipeline handler name.
Definition: pipeline_handler.h:68
virtual int start(Camera *camera, const ControlList *controls)=0
Start capturing from a group of streams.
virtual int exportFrameBuffers(Camera *camera, Stream *stream, std::vector< std::unique_ptr< FrameBuffer >> *buffers)=0
Allocate and export buffers for stream.
MediaDevice * acquireMediaDevice(DeviceEnumerator *enumerator, const DeviceMatch &dm)
Search and acquire a MediaDevice matching a device pattern.
Definition: pipeline_handler.cpp:129
virtual CameraConfiguration * generateConfiguration(Camera *camera, const StreamRoles &roles)=0
Generate a camera configuration for a specified camera.
virtual bool match(DeviceEnumerator *enumerator)=0
Match media devices and create camera instances.
virtual int configure(Camera *camera, CameraConfiguration *config)=0
Configure a group of streams for capture.
void registerCamera(std::shared_ptr< Camera > camera)
Register a camera to the camera manager and pipeline handler.
Definition: pipeline_handler.cpp:533
void registerRequest(Request *request)
Register a request for use by the pipeline handler.
Definition: pipeline_handler.cpp:366
void queueRequest(Request *request)
Queue a request.
Definition: pipeline_handler.cpp:398
bool hasPendingRequests(const Camera *camera) const
Determine if the camera has any requests pending.
Definition: pipeline_handler.cpp:353
void release()
Release exclusive access to the pipeline handler.
Definition: pipeline_handler.cpp:199
void stop(Camera *camera)
Stop capturing from all running streams and cancel pending requests.
Definition: pipeline_handler.cpp:314
bool completeBuffer(Request *request, FrameBuffer *buffer)
Complete a buffer for a request.
Definition: pipeline_handler.cpp:484
CameraManager * manager_
The Camera manager associated with the pipeline handler.
Definition: pipeline_handler.h:77
A frame capture request.
Definition: request.h:31
Video stream for a camera.
Definition: stream.h:74
Framework to manage controls related to an object.
IPA Proxy.
Mutex classes with clang thread safety annotation.
const ControlIdMap controls
List of all supported libcamera controls.
Definition: control_ids.cpp:1301
Top-level libcamera namespace.
Definition: backtrace.h:17
std::vector< StreamRole > StreamRoles
A vector of StreamRole.
Definition: stream.h:71
Base object to support automatic signal disconnection.
Video stream for a Camera.