[libcamera-devel] [PATCH v4 24/31] libcamera: ipu3: Queue request for multiple streams

Jacopo Mondi jacopo at jmondi.org
Wed Mar 20 17:30:48 CET 2019


Add support for queue request on the main and secondary outputs of the
ImgU.

Signed-off-by: Jacopo Mondi <jacopo at jmondi.org>
---
 src/libcamera/pipeline/ipu3/ipu3.cpp | 46 ++++++++++++++++------------
 1 file changed, 27 insertions(+), 19 deletions(-)

diff --git a/src/libcamera/pipeline/ipu3/ipu3.cpp b/src/libcamera/pipeline/ipu3/ipu3.cpp
index ff1e5329c83d..b2df9a4ac922 100644
--- a/src/libcamera/pipeline/ipu3/ipu3.cpp
+++ b/src/libcamera/pipeline/ipu3/ipu3.cpp
@@ -689,38 +689,46 @@ void PipelineHandlerIPU3::stop(Camera *camera)
 
 int PipelineHandlerIPU3::queueRequest(Camera *camera, Request *request)
 {
+	std::set<Stream *> streams = request->streams();
 	IPU3CameraData *data = cameraData(camera);
 	V4L2Device *viewfinder = data->imgu->viewfinder;
 	V4L2Device *output = data->imgu->output;
 	V4L2Device *stat = data->imgu->stat;
-	Stream *stream = &data->streams_[0];
+	ImgUDevice *imgu = data->imgu;
 	Buffer *tmpBuffer;
 
-	/*
-	 * Queue buffer on VF and stat.
-	 * FIXME: this is an hack!
-	 */
-	tmpBuffer = &data->imgu->vfPool.buffers()[tmpBufferCount];
-	viewfinder->queueBuffer(tmpBuffer);
+	for (Stream *stream : streams) {
+		Buffer *buffer = request->findBuffer(stream);
+		if (!buffer) {
+			LOG(IPU3, Error) << "Attempt to queue invalid request";
+			return -ENOENT;
+		}
+
+		V4L2Device *videoDevice = isOutput(data, stream)
+					? output : viewfinder;
+
+		int ret = videoDevice->queueBuffer(buffer);
+		if (ret < 0)
+			return ret;
+
+		if (isOutput(data, stream) && !isViewfinderActive(data)) {
+			tmpBuffer = &imgu->vfPool.buffers()[tmpBufferCount];
+			viewfinder->queueBuffer(tmpBuffer);
+		}
 
+		if (isViewfinder(data, stream) && !isOutputActive(data)) {
+			tmpBuffer = &imgu->outputPool.buffers()[tmpBufferCount];
+			output->queueBuffer(tmpBuffer);
+		}
+	}
+
+	/* Queue buffer on stat unconditionally. */
 	tmpBuffer = &data->imgu->statPool.buffers()[tmpBufferCount];
 	stat->queueBuffer(tmpBuffer);
 
 	tmpBufferCount++;
 	tmpBufferCount %= IPU3_IMGU_BUFFER_COUNT;
 
-	/* Queue a buffer to the ImgU output for capture. */
-	Buffer *buffer = request->findBuffer(stream);
-	if (!buffer) {
-		LOG(IPU3, Error)
-			<< "Attempt to queue request with invalid stream";
-		return -ENOENT;
-	}
-
-	int ret = output->queueBuffer(buffer);
-	if (ret < 0)
-		return ret;
-
 	PipelineHandler::queueRequest(camera, request);
 
 	return 0;
-- 
2.21.0



More information about the libcamera-devel mailing list