[libcamera-devel] [PATCH v3 5/6] [HACK]pipeline: simple: simple.cpp: Hack to test the GL converter

Kunal Agarwal kunalagarwal1072002 at gmail.com
Sun Aug 14 18:07:46 CEST 2022


Includes converter_gl header file and add unicam to list of
supported devices to run on RaspberryPi

Removes parameterized constructor call for SimpleConverter,
which passed Mediadevice converter

Sets Number of streams to 1 when converter is in use

Signed-off-by: Kunal Agarwal <kunalagarwal1072002 at gmail.com>
---
 src/libcamera/pipeline/simple/simple.cpp | 27 ++++++++++++------------
 1 file changed, 13 insertions(+), 14 deletions(-)

diff --git a/src/libcamera/pipeline/simple/simple.cpp b/src/libcamera/pipeline/simple/simple.cpp
index bc0cb1a0..485282fb 100644
--- a/src/libcamera/pipeline/simple/simple.cpp
+++ b/src/libcamera/pipeline/simple/simple.cpp
@@ -36,7 +36,7 @@
 #include "libcamera/internal/v4l2_subdevice.h"
 #include "libcamera/internal/v4l2_videodevice.h"
 
-#include "converter.h"
+#include "converter_gl.h"
 
 namespace libcamera {
 
@@ -187,6 +187,7 @@ static const SimplePipelineInfo supportedDevices[] = {
 	{ "imx7-csi", { { "pxp", 1 } } },
 	{ "qcom-camss", {} },
 	{ "sun6i-csi", {} },
+	{ "unicam", {} },
 };
 
 } /* namespace */
@@ -452,18 +453,16 @@ int SimpleCameraData::init()
 	SimplePipelineHandler *pipe = SimpleCameraData::pipe();
 	int ret;
 
-	/* Open the converter, if any. */
-	MediaDevice *converter = pipe->converter();
-	if (converter) {
-		converter_ = std::make_unique<SimpleConverter>(converter);
-		if (!converter_->isValid()) {
-			LOG(SimplePipeline, Warning)
-				<< "Failed to create converter, disabling format conversion";
-			converter_.reset();
-		} else {
-			converter_->inputBufferReady.connect(this, &SimpleCameraData::converterInputDone);
-			converter_->outputBufferReady.connect(this, &SimpleCameraData::converterOutputDone);
-		}
+	/* Open the converter. */
+
+	converter_ = std::make_unique<SimpleConverter>();
+	if (!converter_->isValid()) {
+		LOG(SimplePipeline, Warning)
+			<< "Failed to create converter, disabling format conversion";
+		converter_.reset();
+	} else {
+		converter_->inputBufferReady.connect(this, &SimpleCameraData::converterInputDone);
+		converter_->outputBufferReady.connect(this, &SimpleCameraData::converterOutputDone);
 	}
 
 	video_ = pipe->video(entities_.back().entity);
@@ -1281,7 +1280,7 @@ bool SimplePipelineHandler::match(DeviceEnumerator *enumerator)
 		DeviceMatch converterMatch(name);
 		converter_ = acquireMediaDevice(enumerator, converterMatch);
 		if (converter_) {
-			numStreams = streams;
+			numStreams = 1;
 			break;
 		}
 	}
-- 
2.25.1



More information about the libcamera-devel mailing list