@@ -24,6 +24,7 @@
namespace libcamera {
+class ControlList;
class FrameBuffer;
class MediaDevice;
class Size;
@@ -73,6 +74,8 @@ public:
std::pair<Rectangle, Rectangle> inputCropBounds() override { return inputCropBounds_; }
std::pair<Rectangle, Rectangle> inputCropBounds(const Stream *stream) override;
+ int applyControls(const Stream *stream, ControlList &ctrls, const V4L2Request *request = nullptr);
+
int allocateRequests(unsigned int count,
std::vector<std::unique_ptr<V4L2Request>> *requests);
@@ -94,6 +97,8 @@ protected:
int start();
void stop();
+ int applyControls(ControlList &ctrls, const V4L2Request *request = nullptr);
+
int queueBuffers(FrameBuffer *input, FrameBuffer *output,
const V4L2Request *request = nullptr);
@@ -18,6 +18,7 @@
#include <libcamera/base/signal.h>
#include <libcamera/base/utils.h>
+#include <libcamera/controls.h>
#include <libcamera/framebuffer.h>
#include <libcamera/geometry.h>
#include <libcamera/stream.h>
@@ -251,6 +252,12 @@ void V4L2M2MConverter::V4L2M2MStream::captureBufferReady(FrameBuffer *buffer)
converter_->outputBufferReady.emit(buffer);
}
+int V4L2M2MConverter::V4L2M2MStream::applyControls(ControlList &ctrls,
+ const V4L2Request *request)
+{
+ return m2m_->capture()->setControls(&ctrls, request);
+};
+
/* -----------------------------------------------------------------------------
* V4L2M2MConverter
*/
@@ -744,6 +751,18 @@ int V4L2M2MConverter::queueBuffers(FrameBuffer *input,
return 0;
}
+/**
+ * libcamera::Converter::applyControls
+ */
+int V4L2M2MConverter::applyControls(const Stream *stream, ControlList &ctrls, const V4L2Request *request)
+{
+ auto iter = streams_.find(stream);
+ if (iter == streams_.end())
+ return -EINVAL;
+
+ return iter->second->applyControls(ctrls, request);
+}
+
/**
* \copydoc libcamera::MediaDevice::allocateRequests
*/