31struct StreamConfiguration;
40 bool isValid()
const {
return m2m_ !=
nullptr; }
45 std::tuple<unsigned int, unsigned int>
49 const std::vector<std::reference_wrapper<StreamConfiguration>> &outputCfg);
51 std::vector<std::unique_ptr<FrameBuffer>> *buffers);
57 const std::map<unsigned int, FrameBuffer *> &outputs);
65 bool isValid()
const {
return m2m_ !=
nullptr; }
67 int configure(
const StreamConfiguration &inputCfg,
68 const StreamConfiguration &outputCfg);
70 std::vector<std::unique_ptr<FrameBuffer>> *buffers);
75 int queueBuffers(FrameBuffer *input, FrameBuffer *output);
78 std::string logPrefix()
const override;
81 void captureBufferReady(FrameBuffer *buffer);
86 std::unique_ptr<V4L2M2MDevice> m2m_;
88 unsigned int inputBufferCount_;
89 unsigned int outputBufferCount_;
92 std::unique_ptr<V4L2M2MDevice> m2m_;
94 std::vector<Stream> streams_;
95 std::map<FrameBuffer *, unsigned int> queue_;
Abstract Base Class for converter.
Definition: converter.h:32
Signal< FrameBuffer * > outputBufferReady
A signal emitted on each frame buffer completion of the output queue.
Definition: converter.h:59
Frame buffer data and its associated dynamic metadata.
Definition: framebuffer.h:50
Base class to support log message extensions.
Definition: log.h:91
Describe a range of sizes.
Definition: geometry.h:201
Describe a two-dimensional size.
Definition: geometry.h:53
Video stream for a camera.
Definition: stream.h:75
The V4L2 M2M converter implements the converter interface based on V4L2 M2M device.
Definition: converter_v4l2_m2m.h:35
V4L2M2MConverter(MediaDevice *media)
Construct a V4L2M2MConverter instance.
Definition: converter_v4l2_m2m.cpp:196
int loadConfiguration(const std::string &filename)
Definition: converter_v4l2_m2m.h:39
int queueBuffers(FrameBuffer *input, const std::map< unsigned int, FrameBuffer * > &outputs)
Queue buffers to converter device.
Definition: converter_v4l2_m2m.cpp:403
std::tuple< unsigned int, unsigned int > strideAndFrameSize(const PixelFormat &pixelFormat, const Size &size)
Retrieve the output stride and frame size for an input configutation.
Definition: converter_v4l2_m2m.cpp:313
void stop()
Stop the converter streaming operation.
Definition: converter_v4l2_m2m.cpp:394
SizeRange sizes(const Size &input)
Retrieve the range of minimum and maximum output sizes for an input size.
Definition: converter_v4l2_m2m.cpp:264
std::vector< PixelFormat > formats(PixelFormat input)
Definition: converter_v4l2_m2m.cpp:224
bool isValid() const
Definition: converter_v4l2_m2m.h:40
int exportBuffers(unsigned int ouput, unsigned int count, std::vector< std::unique_ptr< FrameBuffer > > *buffers)
Export buffers from the converter device.
Definition: converter_v4l2_m2m.cpp:364
int start()
Start the converter streaming operation.
Definition: converter_v4l2_m2m.cpp:376
int configure(const StreamConfiguration &inputCfg, const std::vector< std::reference_wrapper< StreamConfiguration > > &outputCfg)
Configure a set of output stream conversion from an input stream.
Definition: converter_v4l2_m2m.cpp:330
Top-level libcamera namespace.
Definition: backtrace.h:17
Signal & slot implementation.
Configuration parameters for a stream.
Definition: stream.h:41